File No. S360-36 
Form Y27-712 8-0 


I 

[ 

I 


Program Logic 


IBM System/360 Operating System 
Control Program With MFT 

Program Numbers 360S-CI-505, 

360S-DM-508 


This publication describes the internal logic of the 
control program to the extent that it is modified for 
MFT. These modifications affect the job management, 
task management, and data management routines of the 
control program. 

The Program Logic Manual is to be used with the 
program assembly listings and is primarily a guide to 
those listings. It is intended for personnel involved 
in program maintenance and system programmers who are 
altering the system design. Program logic information 
is not necessary for the use and operation of the 
control program; therefore, distribution of this docu¬ 
ment is limited to those with the aforementioned 
requirements. 


Restricted Distribution 



Form ¥27-7128-0 Page Revised by TNL Y27-7157 12/12/67 


PREFACE 


This publication describes the differ¬ 
ences in internal logic that are introduced 
by the expansion of the control program to 
include MFT: multiprogramming with a fixed 
number of tasks. It is assumed that the 
reader of this publication is thoroughly 
familiar with the basic operation of the 
control program. Only areas of difference 
are discussed in detail; however, informa¬ 
tion on sequential scheduling systems in 
general is included where necessary to 
assist the reader in relating new topics to 
known characteristics of the system. 

The manual is divided into four major 
sections. The first section, the Introduc¬ 
tion , outlines the function and organiza¬ 
tion of the entire control program and 
provides references to sources of informa¬ 
tion on various control program elements. 
The Theory of Operation section describes 
control program flow, with emphasis on job 
management operations, which is the aspect 
of the control program most significantly 
different under MFT. The Program Organiza¬ 
tion section provides detailed descriptions 
of added or significantly changed routines. 
The Load Modules and Assembly Modules sec¬ 
tion contains a directory to the contents 
of the nucleus, the SVC library, and the 
link library. 

Information in this document is directed 
to the customer engineer who maintains and 
services IBM System/360 Computing Systems 
and who is responsible for field main¬ 
tenance and updating of IBM System/360 
Operating System. This information may 
also be used by the programming systems 
maintenance programmer and the development 
programmer who will expand the system. 

This publication may be used to locate 
those areas of the system to be analyzed or 


modified. The information is presented to 
enable the reader to relate MFT functions 
to the program listings (coding) for those 
functions. The comments in the listings 
provide information for thorough analysis 
and understanding of the coding. 
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INTRODUCTION 


In a single-task environment main stor¬ 
age is divided into two areas: the fixed or 
system area, and the processing program 
area. In a multiprogramming environment 
with a fixed number of tasks, the process¬ 
ing program area is further divided into 
from one to four partitions. Figure 1 
shows the division of main storage for a 
four-partition system. One task uses each 
partition, and all tasks operate concur¬ 
rently. 


The system area is used for system 
routines that perform control functions 
during the execution of a processing pro¬ 
gram, and for control blocks and tables 
used by the system for the performance of 
those control functions. Each partition is 
used for a processing program and its data, 
control blocks, and tables. 

Option 2 of the control program provides 
for the concurrent execution of up to four 
jobs, each in its own fixed partition of 
main storage. Each job consists of a 
single task. The Option 2 system provides 
for task switching between the user tasks 
operating in the partitions, and between 
those tasks and the communication task 
(master scheduler) in the system area. 

Jobs are sequentially scheduled in the 
Option 2 system. The job scheduling func¬ 
tion is unchanged, except that the capabil¬ 
ity for performing that function in differ¬ 
ent partitions at different times is added. 

With the Option 2 system, task dispatch¬ 
ing differs primarily in that task switch¬ 
ing is required, and that certain system 
functions such as abnormal termination must 
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(Lowest Priority (Highest Priority 
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Figure 1. Storage Allocation for a Four- 
Partition System 


be carried out in such a way that other, 
unrelated tasks are not affected. 


Job and task management functions are 
performed under control program Option 2 
through modified or expanded versions of 
the corresponding routines described in the 


publications IBM System/360 Operating 
System: Job Management, Program Logic Manu¬ 
al , and IBM System/360 Operating System: 
Fixed-Task Supervisor, Program Logic Manu- 
al. General information on those modifica¬ 


tions and expansions is provided in this 


publication. 


FUNCTIONS OF THE CONTROL PROGRAM WITH 
OPTION 2 

Control program routines are grouped 
into three functional areas: 

• Job Management routines. 

• Task Management routines. 

• Data Management routines. 


JOB MANAGEMENT ROUTINES 

Job management routines provide communi¬ 
cation between the user and the operating 
system by: 

• Analyzing the input job stream and 
collecting the information needed to 
prepare a job for execution. 

• Analyzing operator commands, and trans¬ 
mitting messages from a program to the 
operator. 

There are four major job management 
routines: 

• Master scheduler, referred to for the 
Option 2 system as the communication 
task, which analyzes commands from the 
console and transmits messages to the 
operator. 

• Reader/interpreter, which reads the 
input job stream and constructs control 
blocks and tables from information in 
the control statements. 

• Initiator/terminator, which collects 
the information and resources needed to 
execute a job step and performs the 
operations required to terminate a job 
step. 
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• Scheduler controller, which governs the 
sequence in which operation of the 
reader/interpreter and the initiator/ 
terminator occurs in the system*s prob¬ 
lem program partitions; this function 
is added for the Option 2 system. 

The operation of these routines, to the 
extent that operational differences exist, 
is described in this publication. Opera¬ 
tions of these routines that are not signi¬ 
ficantly different in either environment 
are described in the publication IBM 
System/360 Operating System: Job Manage¬ 
ment, Program Logic Manual . 


TASK MANAGEMENT ROUTINES 

Task management routines monitor and 
control the entire operating system, and 
are used throughout the operation of both 
the control and processing programs. 

There are six functions performed by 
these routines: 

• Interruption handling 

• Task supervision 

• Main storage supervision 

• Contents supervision (and program 
fetch) 

• Overlay supervision 

• Time supervision 

The task management routines are collec¬ 
tively referred to as the "supervisor." Of 
these functions, all are identical for 
either environment except for task supervi¬ 
sion, changes to which are discussed in 
this publication. A description of all 
task management routines is given in the 
publication IBM System/360 Operating Sys¬ 
tem: Fixed-Task Supervisor, Program Logic 
Manual. 


DATA MANAGEMENT ROUTINES 

Data management routines control all 
operations associated with input/output 
devices: allocation of space on volumes, 
channel scheduling, storing, naming, and 
cataloging of data sets, movement of data 
between main and auxiliary storage, and 
handling of errors that occur during I/O 
operations. Data management routines are 
used both by problem programs and by con¬ 
trol program routines that require data 
movement. Problem programs use data man¬ 
agement routines primarily to read and 
write data. The control program uses data 
management routines not only to read and 


write required data, but also to locate 
input data sets and to reserve auxiliary 
storage space for output data sets of the 
problem programs. 

There are five categories of data man¬ 
agement routines: 

• Input/output (I/O) supervisor, which 
performs I/O operations and processes 
I/O interruptions. 

• Access methods, which communicate with 
the I/O supervisor. 

• Catalog management, which maintains the 
catalog and locates data sets on auxil¬ 
iary storage. 

• Direct-access device space management 
(DADSM), which allocates auxiliary 
storage space. 

• Open/Close/End-of-Volume, which per¬ 
forms required initialization for I/O 
operations and handles end-of-volume 
conditions. 

Of these routines, the only category 
affected by the selection of control pro¬ 
gram Option 2 is DADSM. All other data 
management routines operate identically 
with or without Option 2. The differences 
in DADSM operation are summarized in the 
"Program Organization" section of this pub¬ 
lication. The operation of all data man¬ 
agement routines is described in the fol¬ 
lowing publications: 

IBM System/360 Operating System: 

Input/Output Supervisor, Program 
Logic Manual ; Form Y28-6616 
IBM System/360 Operating System: Sequen¬ 
tial Access Methods, Program Logic 
Manual ; Form Y28-6604 
IBM System/360 Operating System: Basic 
Direct Access Method, Program Logic 
Manual ; Form Y28-6617 
IBM System/360 Operating System: Catalog 
Management, Program Logic Manual ; 

Form Y28-6606 

IBM System/360 Operating System: Direct 
Access Device Space Management, Pro¬ 
gram Logic Manual ; Form Y28-6607 
IBM System/360 Operating System: 
Input/Output Support 

(OPEN/CLOSE/EOV), Program Logic Manu¬ 
al , Form Y28-6609 


ORGANIZATION OF THE CONTROL PROGRAM 

Different portions of the control pro¬ 
gram operate from different areas of main 
storage. The fixed (system) area of main 
storage is the lower portion of main stor¬ 
age; its size is determined by the control 
program configuration. The system area 
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contains those control program routines 
that perform a system function during the 
execution of a processing program. 

The problem program area is the upper 
portion of main storage. It is defined at 
system generation as containing from two to 
four partitions; the number of partitions 
may be reduced and the size of each may be 
redefined at nucleus initialization, but is 
fixed thereafter until another initial pro¬ 
gram loading (IPL) is performed. Each 
partition may be occupied by a processing 
program, or by control program routines 
that either prepare job steps for execution 
(i.e., job management routines), or handle 
data for a processing program (i.e., the 
access methods). 

On auxiliary storage, the control pro¬ 
gram resides in three partitioned data sets 
that are created when the operating system 
is generated. These data sets are: 

• The NUCLEUS partitioned data set 
(SYS1.NUCLEUS), which contains the 
resident portion of the control program 
and the nucleus initialization program. 

• The SVCLIB partitioned data set 
(SYS1.SVCLIB), which contains the non¬ 
resident SVC routines, nonresident 
error handling routines, and the access 
method routines. 

• The LINKLIB partitioned data set 
(SYS1.LINKLIB), which contains the 
other nonresident control program rou¬ 
tines and the IBM-supplied processing 
programs. 

Figure 2 shows the main storage areas 
into which the routines from each parti¬ 
tioned data set are loaded. 


RESIDENT PORTION OF THE CONTROL PROGRAM 

The resident portion (nucleus) of the 
control program resides in the NUCLEUS 
partitioned data set. This portion of the 
control program is made up of those rou¬ 
tines, control blocks, and tables that are 
brought into main storage at IPL and that 
are never overlaid by another part of the 
operating system. The nucleus is loaded 
into the system area of main storage. 

The resident task management routines 
are: all of the routines that perform 
interruption handling, main storage super¬ 
vision, and time supervision; and some of 
the routines that perform task supervision, 
contents supervision, and overlay supervi¬ 
sion. These routines are described in this 
publication and in the publication IBM 
System/360 Operating System: Fixed-Task 
Supervisor, Program Logic Manual . 


Resident for job management are those 
portions of the communication task that 
receive commands from the operator. The 
communication task is described in this 
publication. 

The resident data management routines 
are the input/output supervisor and the 
BLDL routines, which are part of the parti¬ 
tioned access method. These routines are 
described in the publications IBM 
System/360 Operating System: Input/Output 
Supervisor, Program Logic Manual and IBM 
System/360 Operating System: Sequential 
Access Methods, Program Logic Manual . 


NONRESIDENT PORTION OF THE CONTROL PROGRAM 

The nonresident portion of the control 
program is made up of those routines that 
are loaded into main storage as they are 
needed, and can be overlaid after their 
completion. The nonresident routines oper¬ 
ate from the partitions and from two sec¬ 
tions of the system area called transient 
areas. 

TRANSIENT AREAS: The transient areas are 
two blocks of main storage defined in the 
nucleus and embedded in the system area. 
The first, the SVC transient area, is 
reserved for nonresident SVC routines. The 
second, the I/O supervisor transient area, 
is used by nonresident I/O error handling 
routines that are brought in by the I/O 
supervisor. Each transient area contains 
only one routine at a time. When a nonres¬ 
ident SVC or error handling routine is 
required, it is read into the appropriate 
transient area. All routines read into the 
transient areas reside in SYS1.SVCLIB. 

PARTITIONS: Each partition may be used for 
a processing program as well as for the 
access method routines and the nonresident 
job management routines of the control 
program. When the control program needs 
main storage to build control blocks or for 
a work area, it obtains this space from the 
partition in which the processing program 
that caused the requirement to arise was 
operating. 

Access method routines are brought into 
each partition from SYS1.SVCLIB. Job man¬ 
agement routines are brought in from 
SYS1.LINKLIB. Processing programs are 
brought in from either SYS1.LINKLIB, or a 
user-specified partitioned data set. 

The program area is subdivided as shown 
in Figure 2. Job management routines, 
processing programs, and routines brought 
into storage via a LINK or XCTL macro¬ 
instruction are loaded into the lowest 
available portion of a partition. The 
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highest portion of a partition is occupied 
by a table (the task input/output table) 
built by a job management routine. This 
table is used by data management routines 
and contains information about DD state¬ 
ments. It remains in storage for the whole 
job step. Access method routines and rou¬ 
tines brought into storage via a LOAD macro 
instruction are placed in the highest 
available locations in a partition. 


SYSTEM ENVIRONMENT 
MACHINE TYPES 

The control program with MFT is designed 
for use with IBM System/360, Model 30 or 
higher. A two-partition system using the 
18K scheduler (where K is equal to 1024 
bytes) will operate in a configuration 
having a 64K byte main storage capacity; a 
system having more partitions and/or using 
the 44K or 10OK schedulers requires addi¬ 
tional main storage. 


MINIMUM REQUIRED CONFIGURATION 

Selection of MFT does not affect the 
minimum required configuration. 
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THEORY OF OPERATION 


PROGRAM FLOW 

The stages of program execution under 
the MFT system of the IBM System/360 
Operating System are: 

0. Loading the nucleus into main storage 
(IPL). 

1 • Reading control statements, 

2. Initiating a job step. 

3. Executing a job step, and (optionally) 
activating a lower-priority partition. 

4. Terminating a job step, and (option¬ 
ally) preparing for job scheduling in 
a higher-priority partition. 

The operating system is given control of 
the computer when the control program nuc¬ 
leus is loaded. Thereafter, jobs may be 
processed without reloading the nucleus. 

When the user introduces a job into the 
input stream, the initial processing 
required to prepare his job for execution 
is performed by job management routines. 
Control statements for a complete job are 
read during stage 1. 

Stage 2 is the processing required to 
initiate the execution of a user's job 
step. Stage 3 occurs when CPU control is 
passed to that job step. 

Up to this point, only one partition has 
been active. During stage 3 the problem 
program can cause another partition to 
become active; stages 1, 2, and 3 then 

proceed in that partition. This process 
can be repeated in each partition until all 
are active, with job step execution pro¬ 
ceeding concurrently in each partition. 

The Control Program with MFT is designed 
to operate with single-step, unending jobs 
in all partitions except the partition of 
lowest priority. In that configuration, 
step and job termination normally occur 
only in the lowest-priority partition. 
When a program enters stage 4, job manage¬ 
ment routines perform termination proce¬ 
dures for the step (and, when applicable, 
for the job). 

Upon completion of a job, control passes 
back to stage 1. If further job step 
control statements had been read during 
stage 1, control passes to the initiation 
of the next job step (stage 2). 

The user can, through a system command 
(SHIFT), reverse the process through which 
successive partitions are made active. 
When stage 4 is complete in a partition, 
stage 1 will normally proceed in the same 


partition; however, the user can cause the 
partition from which the terminating parti¬ 
tion was originally activated, rather than 
the terminating partition itself, to be the 
next partition in which stage 1 is to 
proceed. 


When termination is complete for all 
jobs in the system and there are no further 
jobs in the input job stream, the control 
program places the CPU in the wait state. 
As long as the nucleus remains intact in 
main storage, the user can introduce new 
jobs into the job stream without reloading 
the nucleus. 


Reading control statements and initiat¬ 
ing a job step are performed by the reader/ 
interpreter and the initiator/terminator 
routines, respectively. Descriptions of 
these routines are given in the publication 
IBM System/360 Operating System: Job Mana¬ 
gement, Program Logic Manual . 

A job step is performed by a user- 
written program (e.g., a payroll program), 
or an IBM-supplied processing program 
(e.g., linkage editor, COBOL). 

Terminating a job step is performed by 
the initiator/terminator and the super¬ 
visor. Terminator functions peculiar to 
the MFT system are discussed in the "Job 
Management" section of this publication. 
Descriptions of these routines applicable 
to either environment are given in the 
publications IBM System/360 Operating Sys¬ 
tem: Job Management, Program Logic Manual , 
and IBM System/360 Operating System: 

Fixed-Task _ Supervisor, Program Logic 

Manual . 

The routines through which successive 
partitions are activated during problem 
program execution and relinquish control 
after termination are described in the "Job 
Management" section of this publication. 

Figure 3 describes the overall flow of 
CPU control through the job processing 
cycle. These paragraphs describe the pro¬ 
cessing performed by various components of 
the control program as it loads the nuc¬ 
leus, reads control statements, initiates 
the job step, causes processing to oegin or 
end in successive partitions, and ter¬ 
minates the job step. Control program 
processing performed during the execution 
of a job step, including control flow to 
the control program, control flow to a 
processing program, and input/output con¬ 
trol, is unchanged under the MFT system. 
For a discussion of those topics, refer to 
the publication IBM System/360 Operating 
System: Introduction to Control Program 
Logic, Program Logic Manual . 
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To load the nucleus, the operator speci¬ 
fies the device on which the system resi¬ 
dence volume is mounted, and presses the 
load button on the console. This action 
causes an IPL record to be read and to be 
given CPU control. This record reads a 
second IPL record which, in turn, reads the 
rest of the IPL program into main storage. 

The IPL program searches the volume 
label to locate the volume table of con¬ 
tents (VTOC) of the system residence vol¬ 
ume. The volume table of contents is then 
searched for the SYS1.NUCLEUS. The nucleus 
is brought into the system area, and the 
nucleus initialization program (NIP) is 
brought into the dynamic area. NIP 
receives CPU control from the IPL program, 
and initializes the nucleus. Nucleus ini¬ 
tialization includes initializing the con¬ 
trol blocks that establish the absolute 
location and extent of each partition with¬ 
in the processing program area; communi¬ 
cation between the operator and the system 
provides for the redefinition, if desired, 
of the partitions to be used. After com¬ 
pleting its processing, NIP causes the 
reader/interpreter to be brought into the 
| highest-priority scheduler-size partition 
in the problem program area. (NIP remains 
in main storage, but is not re-entered. It 
may or may not be overlayed as successive 
partitions are established. 

When the start reader (START RDR), start 
writer (START WTR), and set date (SET) 
commands are issued, the resulting inter¬ 
ruption causes CPU control to be given to 
the master command routine. After process¬ 
ing the commands, this communication task 
routine passes CPU control to the 
reader/interpreter. The reader/interpreter 
is described in the publication IBM 
System/360 Operating System: Job Manage¬ 
ment, Program Logic Manual . Changes to the 
communication task that, in the MFT system, 
replaces the master scheduler are described 
below. 

The reader/interpreter reads the control 
statements from the input job stream. 
Information from the JOB, EXEC, and DD 
statements is used to control the execution 
of job steps. This information is used to 
construct a job control table (JCT) for the 
job being read, a step control table (SCT) 
for the job step being read, and a job file 
control block (JFCB) and step input/output 
table (SIOT) for each data set being used 
or created by the job step. Information 
from these tables and control blocks is 
combined with information in the data con¬ 
trol block (DCB) and data set control block 
(DSCB) or label when a data set is opened 
during step execution. 


Figure 3. Example of CPU Control Flow for a Job Processing Cycle (Sheet 1 of 4) 
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The reader/interpreter is itself re¬ 
placed by the initiator/terminator routine. 

After receiving CPU control, the 
initiator/terminator prepares to initiate 
the job step that has been read and inter¬ 
preted. Using the data which the 
reader/interpreter extracted from the DD 
statements, the initiator/terminator: 

Locates Input Data Sets : The initiator/ 
terminator determines the volume containing 
a given input data set from the data 
definition (DD) statement, or from a search 
of the catalog. This search is performed 
by a catalog management routine that is 
entered from the initiator/terminator. A 
description of the routines that maintain 
and search the catalog is given in the 
publication IBM System/360 Operating Sys¬ 
tem: Catalog Management, Program Logic 
Manual. 

Assigns I/O Devices : A job step cannot be 
initiated unless there are enough I/O de¬ 
vices to fill its needs. The initiator/ 
terminator determines whether the required 
devices are available, and makes specific 
assignments. If necessary, messages to the 
operator direct the mounting of volumes 
(tapes, etc.). 

Allocates Auxiliary Storage Space : Direct 
access volume space required for output 
data sets of a job step is acquired by the 
initiator/terminator, which uses DADSM. A 
description of the operation of DADSM is 
given in the publication IBM System/360 
Operating System: Direct Access Space Man¬ 
agement, Program Logic Manual . 


The JFCB, which contains information 
concerning the data sets to be used during 
step execution, is written on auxiliary 
storage. This data is used when a data set 
is opened, and when the job step is termi¬ 
nated (e.g., disposition). 


The initiator/terminator causes the 
problem program to be executed. 


The processing program can be one of the 
IBM-supplied processors (e.g., COBOL, link¬ 
age editor),, or a user-written program. 
The processing program uses control program 
services for operations such as loading 
other programs and performing I/O opera¬ 
tions . 


Figure 3. Example of CPU Control Flow for a Job Processing Cycle (Sheet 2 of 4) 
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Initiation of operations in another par¬ 
tition begins when a WAITR macro instruc¬ 
tion is issued in the processing program. 
When a WAITR is encountered, control passes 
to the scheduler controller, which is resi¬ 
dent in the nucleus. That routine restruc¬ 
tures the system job queue in such a way 
that information related to the partition 
from which the WAITR was issued is saved, 
and a new area, to be used in connection 
with the partition now to be activated, is 
available to the reader/ interpreter. Con¬ 
trol then returns to the supervisor. 


After a WAITR has been processed, both 
the partition in which the macro instruc¬ 
tion was issued and the next-lower-priority 
partition contain tasks that are potential¬ 
ly dispatchable. (The communication task 
is always potentially dispatchable, and is 
of higher priority than any partition- 
related task.) When the supervisor is 
re-entered, the task dispatcher dispatches 
the ready task of highest priority; 
therefore, processing continues in the par¬ 
tition from which the WAITR was issued 
until a Wait condition is entered in that 
partition. A Wait causes the 
next-lower-priority-partition• s task to be 
dispatched. This causes the reader/ inter¬ 
preter to receive control. The 
reader/interpreter proceeds as described 
above, exactly as though the new job were 
the first to have been read after IPL or 
START; however, the reader/interpreter is 
now working with a different portion of the 
system job queue and in a different segment 
of main storage. 


When a processing program terminates, 
the supervisor receives CPU control. The 
supervisor uses the OPEN/CLOSE/EOV routines 
to close any open data control blocks. 
These routines are described in the publi¬ 
cation IBM System/360 Operating System: 
Input/Output Support (OPEN/CLOSE/EOV), Pro¬ 
gram Logic Manual . 


Under abnormal termination conditions, 
the supervisor may also provide special 
termination procedures such as a storage 
dump. 


Figure 3. Example of CPU Control Flow for a Job Processing Cycle (Sheet 3 of 4) 
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The supervisor passes control to the 
initiator/terrainator, which is brought into 
the partition in which termination is to 
occur. The initiator/terminator determines 
whether the scheduler is currently asso¬ 
ciated with the partition; if not, the task 
in the terminating partition must WAIT 
until the scheduler has been re-associated 
with the partition. 


When the scheduler is again available, 
the initiator/terminator performs the func¬ 
tions required to terminate individual job 
steps and complete jobs. It executes an 
installation accounting routine if one is 
provided. 


The initiator/terminator releases the 
I/O devices, and disposes of data sets used 
and/or created during the job step. (This 
requires reading tables prepared during 
initiation. Some of these tables are part 
of the system job queue. It is for this 
reason that termination cannot proceed 
until the scheduler has again been asso¬ 
ciated with the terminating partition — 
that is, until the portion of the job queue 
containing information for the terminating 
partition has again become the apparent 
"single" job queue for the system.) 


If the control statements for the next 
job step were read and interpreted, the 
initiator/terminator initiates that step. 
If the statements were not read, the 
initiator/terminator determines whether a 
shift operation is pending. (A shift oper¬ 
ation is pending when a SHIFT command has 
been entered by the operator or encountered 
in the job stream and has not been fully 
effected.) If no shift is outstanding, the 
initiator/terminator is replaced with the 
reader/interpreter, which starts the 
read-initiate-execute-terminate cycle for 
the next job. If a shift is outstanding, 
the initiator transfers control to the 
scheduler controller, which reverses the 
previous restructuring of the job queue so 
that the effective job queue is associated 
with the next-higher-priority partition. 
The scheduler controller then causes the 
reader-interpreter to begin the read- 
initiate-execute-terminate cycle for the 
next higher partition. 


Figure 3. Example of CPU Control Flow for a Job Processing Cycle (Sheet 4 of 4) 
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JOB MANAGEMENT 

Job management (Chart 1) is the first 
and last portion of the control program 
that a job encounters. Its primary 
function is to prepare job steps for execu¬ 
tion and, when they have been executed, to 
direct the disposition of data sets created 
during execution. Prior to step execution, 
job management: 


• Reads control statements from the input 
job stream. 

• Places information contained in the 
statements into a series of tables. 

• Analyzes input/output (I/O) require¬ 
ments . 

• Assigns I/O devices. 

• Passes control to the job step. 

Following step execution, job manage¬ 
ment: 

• Releases main storage space occupied by 
the tables. 

• Frees I/O devices assigned to the step. 

• Disposes of data sets referred to or 
created during execution. 

Job management also performs all pro¬ 
cessing required for communication between 
the operator and the control program. 
Major components of job management are the 
job scheduler, which introduces each job 
step to System/360, and the communication 
task, which handles all operator-system 
communication. 


JOB SCHEDULER FUNCTIONS 

The job scheduler includes three pro¬ 
grams: the reader/interpreter, the 
initiator/terminator and the scheduler 
controller. The functions of the reader/ 
interpreter are unchanged from the sequen¬ 
tial scheduling system; for further infor¬ 
mation, refer to the publication IBM 
System/360 Operating System: Job Manage¬ 
ment, Program Logic Manual . 

After all control statements for a job 
have been processed, or when data is 
encountered in the input job stream, the 
reader/interpreter gives control to the 
initiator/terminator. The initiator por¬ 
tion of the initiator/terminator function 
is unchanged from the sequential scheduling 
system; for further information, refer to 


the publication IBM System/360 Operating 
System: Job Management, Program Logic Manu¬ 
al . 

When the job step has been executed, 
control is again given to the initiator/ 
terminator which, when the scheduler is 
assigned to the partition in which the job 
step has executed, performs data set dispo¬ 
sitions and releases I/O resources. The 
shift count is interrogated, at job termi¬ 
nation, to determine if the scheduler is to 
be shifted into a higher priority parti¬ 
tion. 


COMMUNICATION TASK FUNCTIONS 

The routines of the communication task 
process the following types of communi¬ 
cation between the operator and the system. 

• Operator commands, whether they are 
issued through the console or through 
the input job stream. 

• Write-to-operator (WTO) and write-to- 
operator with reply (WTOR) macro¬ 
instructions . 

• Interruptions caused when the INTERRUPT 
key is pressed. 


JOB PROCESSING 

Figure 4 shows the major components of 
job management and illustrates the general 
flow of control. 

Control is passed to job management 
whenever the supervisor finds that there 
are no program request blocks in the 
request block queue. This can occur for 
two reasons: either the initial program 
loading (IPL) procedure has just been com¬ 
pleted or a job step has just been execut¬ 
ed. 


Entry to Job Management Following Initial 
Program Loading 

Following IPL, certain actions must be 
taken by the operator before job processing 
can begin. Therefore, control passes to 
the communication task and a message is 
issued to the operator instructing him to 
enter commands. These "initialization" 
commands include a SET command, a start 
writer (START WTR) command, and a start 
reader (START RDR) command. When a START 
command with a blank operand is issued, 
control is passed to the reader/inter¬ 
preter. 
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* * 

* PROCESS * 

♦INITIALIZATION *X. 

* COMMANDS * 

* * 
***************** 
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***************** 


**+**C2********** 


***************** 


****A3********* 
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****C3********* 

* * 
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* * 
*************** 


*****C4********** 

* DO POST-STEP * 
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* ROUTINE * 
****** *********** * 


X 
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X 
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***************** 


X 
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* PRIORITY * 

* PARTITION * 
***************** 



*****H1********** 

* * 
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***************** 


X 
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* CONTROL *X... 
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* * . 

***************** # 

. **** 

. * * 

• * G2 * 

• * * 

• **** 
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.*. 
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. * * . 

YES .* COMMAND *. 
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*. .* 

*. .* 
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,X 
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♦STEP. ALLOCATE * 

* I/O DEVICES * 

* * 
***************** 


♦****K3********** 

* ON WAITR, * 
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. * PRIORITY PTN * 

. * * 

X ***************** 
**** 

* * 

* G2 * 

* * 

**** 


X 
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* EXIT TO * 
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* PROGRAM * 
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Figure 4. Job Management Logic 
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Entry to Job Management Following Step 
Execution 

Following step execution, control is 
routed to the step termination routine of 
the initiator/terminator. If the job had 
been completed, control is also passed to 
the job termination routine of the 
initiator/terminator. Both routines are 
described under "Job and Step Termination," 


Control Statement Processing 

After completion of the processing that 
immediately follows IPL, or after termina¬ 
tion of a job or of a step containing data 
in the input job stream, control is passed 
to the reader/interpreter. The reader/ 
interpreter reads and processes control 
statements until one of the following con¬ 
ditions is encountered: 

• A DD * or DD DATA statement. 

• Another JOB statement. 

• A null statement. 

• An end-of-data set (EOF) on the system 
input device. 

Meanwhile, if the operator has pressed 
the REQUEST key and has entered a request 
(REQ) command during execution of the job 
step or any of the above processing, the 
communication task routines set a command- 
pending indicator on during the ensuing 
interruption. The indicator is now checked 
and, if found to be on, control is passed 
to the communication task, which causes a 
message to be issued instructing the 
operator to enter commands, and then pro¬ 
cesses the commands. 

Step Initiation 

Control next passes to the 

initiator/terminator, which examines I/O 
device requirements, assigns (allocates) 
I/O devices to the job step, issues mount¬ 
ing instructions, and verifies that volumes 
have been mounted on the correct units. 
Finally, the initiator/terminator passes 
control to the job step. 

Job and Step Termination 

When processing program execution is 
completed, the supervisor, finding no pro¬ 
gram request blocks in its request block 
queue, passes control to the job management 
routines. Entry is first made to the step 
termination routine. 

Step termination may occur only when the 
scheduler is attached to the terminating 
partition. If termination cannot occur. 


the pre-termination routine issues a 
'PARTITION n WAITING TO TERMINATE' message 
and waits until the partition gains control 
of the scheduler. The step termination 
routine performs end-of-step housekeeping 
and passes control to the user's accounting 
routine, if one was provided. When the 
accounting routine has been executed, the 
supervisor returns control to the step 
termination routine. If the job termina¬ 
tion indicator is on, control is then 
passed to the job termination routine; or 
to the reader/interpreter if the indicator 
is off and no more steps are ready for 
initiation? or to the step initiation rou¬ 
tine. 

The job termination routine performs 
end-of-job housekeeping. It exits to the 
user's accounting routine, if one was pro¬ 
vided. After the accounting routine is 
executed, the supervisor returns control to 
the job termination routine which decre¬ 
ments the partition shift count by one if 
neither the partition number nor shift 
count is already zero. Control is then 
passed to the reader/interpreter. 


OPERATOR-SYSTEM COMMUNICATION PROCESSING 

The routines that handle operator-system 
communication are contained in the communi¬ 
cation task. Communication may take one of 
two forms: commands, which allow the opera¬ 
tor to change the status of the system or 
of a job or job step? and the WTO or WTOR 
macro-instructions, which allow processing 
programs or system components to issue 
messages to the operator. The communi¬ 
cation task routines also switch functions 
from the primary console device to an 
alternate console device when the INTERRUPT 
key is pressed. 


Command Processing 

Commands may be issued by the operator 
in two ways: he may insert command state¬ 
ments between job steps in the input job 
stream, or he may issue commands through 
the console input device. Commands encoun¬ 
tered in the input job stream cause control 
to be passed to the communication task, 
which processes them. Before entering com¬ 
mands through the console, however, the 
operator must press the REQUEST key to 
cause an attention interruption. Figure 5 
shows the actions taken after the key is 
pressed. 

WTO/WTOR Macro-Instruction Processing 

Whenever the WTO or WTOR macro¬ 
instruction is issued, a supervisor 
interruption occurs. (See Figure 6.) 
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External Interruption Processing 

When the operator presses the INTERRUPT 
key, an external interruption occurs. The 
communication task then switches functions 
from the primary to the alternate console 
I/O device. (See Figure 7.) 


ENQ/DEQ PROCESSING 

The enqueue and dequeue service rou¬ 
tines, through which the ENQ and DEQ macro¬ 
instructions are implemented, provide for 
controlled, sequential access to serially 
reusable resources such as data sets, 
programs, or work areas in main storage. 
The routines service both problem program 
ENQ/DEQ requests, and requests from the 
system's job management and fixed-task 
supervision routines. The primary function 
of the enqueue and dequeue service routines 
is to test for the availability to the 
requesting task of a serially reusable 
resource, to enqueue the request if neces¬ 
sary, and to dequeue the request when use 
of the resource is complete. 

In addition, the service routines permit 
system routines to set a system-must- 
complete flag before performing a critical 
operation, then to remove*(reset) the flag 
when the operation has been successfully 
completed. This feature is available only 
to system routines; use of the system-must- 
complete feature in a problem program 
causes abnormal termination. 


ENQ/DEQ Control Blocks 

Resources are identified by the request¬ 
er through a major name, specifying a set 
of resources, and a minor name, specifying 
a particular resource within that set. An 


Supervisor 



Figure 5. Attention Interruption Process¬ 
ing Flow 


Supervisor 



A. Message Processing 


Supervisor 



B. Reply Processing 

Figure 6. WTO/WTOR Macro-Instruction 
Processing Flow 


enqueued request has associated with it 
three control blocks: a major queue control 
block (QCB), a minor QCB, and a queue 
element. (See the program listing for the 
structure and contents of these control 
blocks.) 

The major QCB represents the set of 
resources specified by the major name pa¬ 
rameter of the ENQ request. All major QCBs 
existing in the system at a given time are 
linked together; the head of the major QCB 
chain is a control field (IEAQQCBO) within 
the enqueue service routine. 

Queued on each major QCB are the minor 
QCBs corresponding to the minor names of 
the specific resources for which requests 
have been issued. Queued on each minor QCB 
are queue elements representing the tasks 
under which the outstanding requests were 
issued. 
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Operator Presses 
INTERRUPT Key 

Communication Task 


Switches between 
Primary and 
Alternate 
Console 


Supervisor 


Identifies Type of 
Interruption, Posts 
to Communication 
Task ECB 


Returns Control 
to point of 
Interruption 


Figure 7. External Interruption Process¬ 
ing Flow 


Note: If the STEP operand is included in 
an ENQ or DEQ macro-instruction f the pro¬ 
tection key for the job step is treated as 
part of the minor name when the minor QCB 
queue is searched. If two requests specify 
the same major and minor name and if either 
request or both includes the STEP operand, 
both requests will be represented by the 
same major QCB but different minor QCBs. 
However, because the Option 2 system does 
not include the ATTACH and DETACH macro¬ 
instructions, the STEP operand has no 
effect. 


If the SYSTEM operand is included in an 
ENQ or DEQ macro-instruction, the minor 
name is used as specified. Two requests 
specifying the same major and minor name 
and SYSTEM will be represented by the same 
major QCB and the same minor QCB. 


All ENQ/DEQ control blocks are dynami¬ 
cally created and deleted, as ENQ and DEQ 
requests are processed and as other system 
functions, such as abnormal termination, 
are performed. The physical location of 
the major and minor QCBs, with respect to 
the partition in which the requesting task 
was operating, varies depending upon the 
circumstances of their creation and dele¬ 
tion. When an ENQ request is serviced, a 
GETMAIN is issued to obtain main storage 
for a major QCB, a minor QCB, and a queue 
element. The queue element is always 
developed and linked to the appropriate 
control block; queue elements remain in the 
requesting partition from their creation 
(on ENQ) until their deletion (normally on 
DEQ). The main storage obtained for the 
QCBs may or may not be used at the time 
that the queue element is created. Major 
and minor QCBs are copied from partition to 
partition as required by the sequence in 
which queue elements are dequeued. If the 
required major and/or minor QCB already 
exist in another partition, the correspond¬ 
ing area(s) in the requesting partition is 


reserved for use if it becomes necessary to 
copy the QCB(s) into the requesting parti¬ 
tion. 


For a summary of typical control block 
patterns during ENQ/DEQ, see Figure 8. 


Sequence of Execution for Enqueued Tasks 

The queue elements enqueued upon any one 
minor QCB represent tasks that have 
requested access to the corresponding 
resource. When control within a task pass¬ 
es to the enqueue service routine, the task 
may enter an effective wait until the 
request is serviced; that is, control is 
not returned from the enqueue service rou¬ 
tine to the processing program until the 
resource has actually been made available 
to the task. The time at which a task 
proceeds (through re-entry to the calling 
routine) is determined by the relative 
position of shared and exclusive requests 
on the queue, and by the status of each, as 
described in the following paragraphs. 


A queue element may be thought of as 
being ready or not-ready, where the condi¬ 
tion ascribed to the queue element is 
actually the condition of the associated 
task. Then an ENQ specifying several 
resources is issued, the wait count in the 
SVC request block (SVRB) associated with 
the request is set to the number of resour¬ 
ces requested by, but unavailable to, the 
task. Whenever the wait count in an SVRB 
is non-zero, the routine to which the SVRB 
points cannot proceed, although the the 
task with which the SVRB is associated may 
not be waiting. This condition is summar¬ 
ized by describing the queue element as 
not-ready. Conversely, a queue element may 
be described as "ready" when the wait count 
in the associated SVRB is zero. 


If any queue element preceding the first 
exclusive request on the queue for a 
resource is shared and ready, the task 
associated with that queue element pro¬ 
ceeds. Furthermore, the tasks represented 
by any subsequent shared and ready requests 
on the queue that precede the first exclu¬ 
sive request proceed concurrently. The 
first exclusive request, whether ready or 
not-ready, and all subsequent requests, 
whether exclusive or shared, are not ser¬ 
viced at this time. 

If the queue element at the head of the 
queue is exclusive and ready, the task 
associated with that queue element pro¬ 
ceeds. No other task represented on that 
queue proceeds until the exclusive request 
has been dequeued. 
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PARTITION C 


An ENQ is issued in partition A. None of the 
required control blocks exist — therefore, all 
three are created in partition A. 


MINOR 

QCB 

QEL 


An ENQ is issued in partition B. A QCB 
exists for the specified major name, but not 
for the minor name. Major QCB space is 
reserved in partition B. The minor QCB is 
created and added to the chain of minor QCBs 
for the existing major QCB. The new queue 
element is created. 
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Two ENQs are issued in partition C. The 
first request names a new set of resources; a 
full set of control blocks is created and the 
major QCB is linked to the existing major 
QCB. 






—► 

QEL 


The second request is for the same resource 
ENQd upon in partition B. Since both a 
major and a minor QCB exist, the correspon¬ 
ding space in partition C is reserved; a queue 
element is created and added to the minor 
QCB's queue element chain. 




MAJOR 

QCB 



MINOR 

QCB 

QEL 
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A DEQ is issued in partition A. Because 
there is a second minor QCB (in partition B) 
chained to the major QCB, the major QCB 
is copied into the reserved space in partition 
B. Since there are no further QELs enqueued 
on the minor QCB in partition A, it need not 
be copied. The QEL is no longer required. 
(QELs are never copied.) After the major 
QCB has been copied, the main storage used 
for all three control blocks is freed. 
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A DEQ is issued in partition B. There are 
no further minor QCBs in the major QCBs 
chain, but there is another QEL linked to 
the minor QCB. Therefore, both the major 
and the minor QCBs are copied into the 
reserved space associated with the remain¬ 
ing QEL. The control blocks in the DEQing 
partition are then deleted via FREEMAIN. 


o 


head of major 
QCB queue (addr 
in IEAQQCB0) 



link pointer 
copy operation 


Figure 8. ENQ/DEQ Control Block Creation and Deletion 
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If the queue element at the head of the 
queue is exclusive and not-ready, no tasks 
represented on the queue can proceed. 


LOAD MODULES 

Most job management routines exist as a 
series of load modules that reside on a 
permanently resident volume. The only 
exceptions are the posting routines of the 
communication task, which reside in the 
nucleus. The "Load Modules and Assembly 
Modules" section contains a list of the 
routines that make up each job management 
load module. 
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PROGRAM ORGANIZATION 


JOB SCHEDULER MODIFICATIONS 

PARTITION-RELATED SCHEDULER CONTROL BLOCK 

The partition-related scheduler control 
block (PRSCB) is the only new control block 
introduced into the system by Option 2 of 
the control program. One PRSCB is created 
for each partition at nucleus initializa¬ 
tion. The PRSCBs reside in the nucleus, as 
module IEFSD032, and are defined by a 
DSECT, module IEFSD033. PRSCBs are con¬ 
tiguous and are arranged by priority order, 
beginning with highest priority (Partition 
0). A pointer to the PRSCB for a given 
partition is contained in the three bytes 
immediately preceding the boundary box for 
that partition. The content and structure 
of the PRSCB are described below. 


r - 1 

| SD33ECB | 

h-^ 

| SD33CTTR | 

I--H 

| SD33STTR | 

I Til 

| SD33QSTT | SD33LNGH) SD33IND j 

I III 

L-X-X-J 


Field Bytes Contents 

SD33ECB 4 Scheduler-controlling event 
control block. This ECB is 
posted complete whenever the 
scheduler is assigned to the 
partition through a WAITR 
issued in the next-higher- 
priority partition. The 
wait flag in this ECB is 
turned on when the scheduler 
is relinguished, either 
through a WAITR in this par¬ 
tition or through processing 
of a SHIFT command. 

SD33CTTR 4 Current TTR save area. When 
a partition relinquishes 
scheduler control through a 
WAITR, the scheduler down¬ 
shift routine stores in this 
field (in TTR form) the next 
location in the queue- 
managers extent that would 
have been used by the 


Field Bytes Contents 

queue-manager if further 
records were to have been 
written for the relinquish¬ 
ing partition. The system 
job queue variable area 
applicable to the next- 
lower- priority partition 
begins on the next full 
track following this loca¬ 
tion. 


SD33STTR 4 Fixed-area table save area. 

When a partition relinquish¬ 
es scheduler control through 
a WAITR, the relinquishing 
partition's JCT, SCT, and 
LCT are moved from the fixed 
area to this save area, fol¬ 
lowing the variable informa¬ 
tion for the relinquishing 
partition. 

SD33QSTT 2 Starting track location save 
area. This area contains 
(in TT form) the location of 
the track on which the vari¬ 
able area for the partition 
begins. 

SD33LNGH 1 Offset to PRSCB for active 
partition. This byte is 
meaningful only in the PRSCB 
for Partition 0. Whenever a 
scheduler upshift or down¬ 
shift is effected, the 
length of one PRSCB (16 
bytes) is added to or sub¬ 
tracted from this field in 
the Partition 0 PRSCB. This 
value, added to the address 
of the PRSCB Partition 0, 
yields the address of the 
PRSCB for the partition to 
which the scheduler is cur¬ 
rently assigned. 


SD33IND 1 Partition identification; 

contains 00 for Partition 0, 
01 for Partition 1, etc. 


TERMINATION 


The termination function of the 
initiator/terminator (Chart 12) performs 
post-step and post-job housekeeping. It is 
normally given control following step exe¬ 
cution, but is also given control when a 
job management routine encounters an 
irrecoverable error while processing a job 
step. Termination routines: 
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• Release space occupied by tables, 

• Free I/O devices, 

• Dispose of data sets referred to or 
created during execution. 

Major components of termination are: 

• The pre-termination routine, which de¬ 
termines if the scheduler is currently 
associated with the terminating parti¬ 
tion, 

• The step termination routine, which 
performs post-step housekeeping func¬ 
tions. 

• The job termination routine, which per¬ 
forms post-job housekeeping functions. 

• The shift count interrogator, which 
determines whether a shift is to be 
performed. 

The disposition and unallocation subrou¬ 
tine is used by both the step and job 
termination routines. Basically, this sub¬ 
routine handies disposition of data sets 
and frees devices allocated to a step. The 
disposition and unallocation subroutine is 
described in the publication IBM System/360 
Operating System; Job Management, Program 
Logic Manual . 


PRE-TERMINATION ROUTINE: The pre¬ 
termination routine (Chart 13) is new for 
the Option 2 system. The routine is 
entered from the supervisor when the prob¬ 
lem program has issued its highest-level 
return, causing the supervisor's ABEND rou¬ 
tine to be entered; the second load module 
of the ABEND routine exits to the job 
management GO module. 

Working through the communication vector 
table, the pre-termination routine obtains 
the address of the TCB for the current task 
(the task that is attempting to terminate), 
obtains from the TCB a pointer to the 
related boundary box, and obtains from the 
boundary box the address of the partition- 
related scheduler control block (PRSCB) for 
the partition in which the terminating task 
was operating (see Figure 9). The first 
fullword of the PRSCB is the scheduler¬ 
controlling ECB for that partition. 

The ECB is posted complete if the 
terminating partition has never issued a 
first WAITR macro-instruction, and has 
therefore never relinquished control of the 
scheduler, or if the partition has relin¬ 
quished control but has again been assigned 
scheduler control through SHIFT command 
processing. If the wait flag is on in the 
ECB, the partition has relinquished schedu¬ 


ler control through a WAITR and the schedu¬ 
ler is currently oriented toward some par¬ 
tition of lower priority; termination can 
proceed only after the scheduler has been 
re-associated with the terminating parti¬ 
tion. 

If the wait flag is on in the 
scheduler-controlling ECB for the 
terminating partition, the pre-termination 
routine issues a 1 PARTITION n WAITING TO 
TERMINATE' message and waits on the ECB. 
(The ECB is posted complete when a SHIFT 
command causes the scheduler upshift rou¬ 
tine to pass control of the scheduler from 
the next-lower-priority partition to this 
partition.) If the complete flag is on, 
the routine bypasses the message, issues a 
WAIT on the ECB to decrement the wait 
count, and continues processing. 

When the wait for scheduler control is 
satisfied, the pre-termination routine 
examines the completion code in the ECB. A 
completion code of 4 indicates that schedu¬ 
ler control was relinquished by, and 
returned to, the terminating partition. 
Control was originally relinquished through 
a WAITR macro-instruction; when the WAITR 
was processed, the first-time WAITR switch 
for this partition was turned off. If this 
is the case, the pre-termination routine 
turns the switch back on, in preparation 
for the first WAITR macro-instruction in 
the next job (if any) to be scheduled into 
the terminating partition, and resets the 
completion code in the ECB to zeros. 

If the completion code is not h, the 
terminating partition has never relin¬ 
quished control and its first-time WAITR 
switch is, therefore, still on. In this 
case, resetting the switch is bypassed. 

When these actions are complete, the 
pre-termination routine enters the step 
termination routine through a branch. 


STEP TERMINATION ROUTINE: The step termi¬ 
nation routine performs its functions when 
a step has been terminated either normally 
due to successful completion of execution 
or abnormally due to an error condition. 
It uses five major routines: 

• Step termination control routine. 

• Step termination data set driver rou¬ 
tine. 

• Job statement condition code routine. 

• Disposition and unallocation subrou¬ 
tine. 

• User's accounting routine (if included 
in the configuration). 
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Figure 9. Control Block Relationships 
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Upon successful execution of a step or 
abnormal termination of execution, control 
is passed from the supervisor to the step 
termination control routine. In addition, 
when a job management routine encounters an 
irrecoverable error, it immediately passes 
control to the step termination control 
routine. 

First, the initiator/terminator task 
input/output table (TIOT) and the linkage 
control table (LCT) are read into main 
storage. Next, the cancel ECB is set to 
zero in the selected job queue. The job 
control table (JCT) and the step control 
table (SCT) are then read into main storage 
(if they are not in main storage at the 
time), and a step status code is inserted 
into the SCT. 

The step data set driver routine is then 
entered. It reads the step input/output 
table (SIOT) for each data set into main 
storage and branches to the disposition and 
unallocation subroutine. The loop through 
the data set driver routine and the dispo¬ 
sition and unallocation subroutine is then 
repeated for each SIOT. 

When all data sets have been processed 
by the disposition and unallocation subrou¬ 
tine, the updated SCT is returned to auxil¬ 
iary storage. Control is then passed to 
the job statement condition code routine, 
unless it is known that there are no 
further steps for the job (the reader/ 
interpreter had encountered a JOB or null 
statement). In the latter case the job 
statement condition code routine is 
bypassed. 

The job statement condition code routine 
processes condition codes specified in the 
JOB statement. 

If, upon entry into the job statement 
condition code routine, it is found that 
there were no condition codes specified in 
the JOB statement, control is returned to 
the step termination routine. Each condi¬ 
tion code in the JCT for the job is in turn 
compared with the step completion code of 
the previous step, which appears in its 
SCT. Up to eight conditions are checked by 
this routine for each step. Any additional 
condition codes are ignored. If any of the 
condition operators are satisfied by the 
codes, the job-failed indicator in the JCT 
is updated to indicate that the job failed, 
the message subroutine is used to issue a 
message to the programmer, and control is 
returned to the step termination routine. 

Upon return from the job statement con¬ 
dition code routine, or if it had been 
bypassed, the step termination routine 
exits to the user's accounting routine, if 
one is present. On return from the 


accounting routine, or if there was none, 
the step termination routine passes control 
to: 

• The job termination routine, if the 
current step is known to be the last 
step of the job. 

• The initiator/terminator system control 
routine, if additional steps have been 
interpreted and are ready to be ini¬ 
tiated. 

• The reader/interpreter control routine, 
which resumes processing the input job 
stream. 


JOB TERMINATION ROUTINE: The job termina¬ 
tion routine (Chart 15) performs its func¬ 
tions when an entire job has been executed 
and step termination for its last step has 
been completed. It consists of four major 
routines: 

• Job termination control routine. 

• Release job queue routine. 

• Disposition and unallocation subrou¬ 
tine. 

• User's accounting routine (if included 
in the configuration). 

Control is passed to the job termination 
control routine from the step termination 
routine. 

The job termination control routine de¬ 
termines if a passed data set queue exists 
and, if so, reads each block into main 
storage and tests for unreceived data sets. 
(An unreceived data set is a passed data 
set to which no reference is made after 
PASS is specified.) When an unreceived 
data set is found, entry is made to the 
disposition and unallocation subroutine. 
When all unreceived data sets have been 
processed, or if no passed data set queue 
exists, the job termination control routine 
passes control to the accounting routine, 
if there is one. 

When the accounting routine returns, or 
if there is no accounting routine, the 
completed job's control tables are removed 
from the system by the release job queue 
routine. This routine releases the auxil¬ 
iary storage space occupied by all control 
tables for the job. If the job notifica¬ 
tion switch is on, the message 

IEF402I jobname ENDED 

is written on the console device. Control 
is then passed to the shift count interro¬ 
gation routine. 
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SHIFT COUNT INTERROGATION ROUTINE: For the 
Option 2 system, the shift count interroga¬ 
tor (Chart 16) is added as the final step 
of the job termination routine. If the 
scheduler is not already in partition 0 and 
the shift count is not zero, the count is 
decremented by one and control is passed to 
the scheduler upshift routine. Otherwise 
the shift count is zeroed out and control 
is passed to the reader/interpreter control 
routine. 


SCHEDULER CONTROLLER 

Acting in conjunction with the 
reader/interpreter and the initiator/ter¬ 
minator , the scheduler controller is the 
third element of the job scheduler. The 
function of the controller is to adjust the 
system job queue and monitor the operation 
of the reader/interpreter and initiator/ 
terminator as required for multi-partition 
processing. 

The system job queue is a data set 
containing control information produced by 
the reader/interpreter and used throughout 
job scheduling. The direct access area on 
which the data set resides is known as the 
queue-manager extent (see Figure 10). This 
extent is defined at system generation time 
and is initialized at nucleus initializa¬ 
tion. 

During initial reader/interpreter opera¬ 
tions — that is, up until the time when 
the first job in the input stream begins 
execution and issues a WAITR — the con¬ 
tents of the queue-manager extent is organ¬ 
ized as for the sequential scheduled sys¬ 
tem. The extent includes a fixed area 
(sometimes referred to as the "pre-empted 
track area") immediately followed by a 
variable area. Within the fixed area are, 
among other control fields, three key con¬ 
trol tables: a link control table (LCT), a 
job control table (JCT), and a step control 
table (SCT)• The variable area contains 
additional control fields and tables. 
(Each record in the variable area is fixed 
at 176 bytes; however, the number of 
records in the area can vary.) 

Major scheduler control components are: 

• The downshift routine, which reinitial¬ 
izes the scheduler for operation in the 
next-lower-priority partition. 

• The upshift routine, which is entered 
when the scheduler is to be shifted to 
the next-higher-priority partition. 

SCHEDULER DOWNSHIFT ROUTINE: The scheduler 
downshift routine (Chart 18) is entered as 
a result of WAITR issuance in the next- 
higher- priority partition. This routine 


reinitializes the scheduler for operation 
in the next-lower-priority partition, 
issues the message 

PARTITION n STARTED 

and exits to the reader/interpreter. The 
following paragraphs describe how prepara¬ 
tion for scheduling in the second partition 
is performed. (Throughout the following 
discussion, 'Partition A' refers to the 
partition in which the WAITR was issued and 
which is relinquishing the scheduler. 
'Partition B* refers to the next-lower- 
priority partition — the partition to 
which the scheduler is being assigned.) 

When the scheduler downshift routine is 
entered, the PRSCB for Partition B is 
cleared to zeroes, except for the complete 
flag in the scheduler-controlling ECB, 
which was just set on by the WAITR routine, 
and the partition identification byte which 
remains constant. The routine then gets 
main storage and reads in the LCT, JCT, and 
SCT from the queue-manager's extent on 
direct access. New job, link, and step 
control tables are constructed and read 
back into the fixed area; the tables that 
were read in from the fixed area are then 
written into the variable area associated 
with Partition A. 

The variable area associated with 
Partition A now contains the scheduler 
information in the same state as when the 
scheduler was operating in that partition. 
The control information in the standard 
portion of the variable area is applicable 
only to Partition A and will not be affect¬ 
ed by operation of the scheduler in another 
partition. The control information in 
those portions of the fixed area that are 
always referred to by the scheduler (the 
LCT, SCT, and JCT), regardless of what 
partition it is operating in, has been 
saved and the fixed area re-initialized for 
further use. 

When this operation is complete, the 
pointers in the PRSCB for Partition A 
indicate (in TTR form) the location of: 

SD33QSTT The beginning of Partition A's 
variable area. 

SD33STTR The beginning of the LCT/SCT/JCT 
save area within that variable 
area. 

SD33CTTR The next available TTR on the 
queue-manager's extent; i.e., the 
location beyond which the vari¬ 
able area for Partition B, if one 
is required, is to be built. 

Control is then passed to the reader- 
interpreter. 
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QUEUE-MANAGER'S EXTENT 



The fixed area (described by 
DSECT IEFSD005) is used for , 
scheduling in any partition. / 


* These tables are used for scheduling the active 
partition, and are saved in the variable area 
associated with the active partition when sched¬ 
uler control is relinquished. 


/ 




PARTITION 0 
(First Variable Area) 

A 




PARTITION 1 
(Second Variable Area) 

_A_ 





uling when partition has 
scheduler control 


tables are stored when 
control is relinquished 


Figure 10. Queue-manager*s Extent Layout 


SCHEDULER UPSHIFT ROUTINE: The scheduler 
upshift routine (Chart 17) is entered from 
the shift count interrogator when job 
termination has been completed in a parti¬ 
tion (Partition B, for purposes of 
discussion) and the scheduler is to be 
shifted to the next-higher-priority parti¬ 
tion (Partition A) in response to a non¬ 
zero shift count. 

When the scheduler upshift routine is 
entered, the last of the scheduler's 
termination routines has already issued a 
GETMAIN for main storage to be used by the 


reader/interpreter. This main storage is 
freed, and a GETMAIN is issued to obtain 
the main storage required by the pointer 
restore routine. Into this main storage is 
read the LCT, SCT, and JCT associated with 
Partition A. 

After reading the required control 
tables into main storage, the routine 
writes them into the queue-manager's fixed 
area and resets the queue-manager 1 s 'active 
area' pointer (SCATALLY) to the beginning 
of Partition A's variable area. The con¬ 
trol information available to the queue 
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manager is now in exactly the same status 
as it was when scheduler control was ini¬ 
tially relinquished. 

With the scheduler switch complete, the 
routine posts the scheduler-controlling ECB 
for Partition A and issues a wait on the 
ECB for Partition B. This wait is satis¬ 
fied if a subsequent job scheduled into 
Partition A issues a WAITR; if the wait is 
satisfied, the scheduler downshift routine 
is brought into Partition B and executed. 


COMMUNICATION TASK 

The communication task (Chart 02) pro¬ 
cesses all operator commands and messages 
directed to the operator through use of the 
WTO and WTOR macro-instructions. It also 
performs console switching when the secon¬ 
dary console is to be used in place of the 
primary console. 

The eight major routines of the communi¬ 
cation task are: 

Console interrupt routine , which noti¬ 
fies the communication task wait routine 
that a console read has been requested. 

Communication task wait routine , which 
waits for all WTO/WTOR requests and 
console interrupts and calls the com¬ 
munication task router routine. 

Communication task router routine , which 
determines the type of request or inter¬ 
rupt that occurred and passes control to 
the appropriate processing routine. 

Console device processor routine , which 
performs console read and write opera¬ 
tions and error checking. 

Master command processor routine , which 
processes all commands read from the 
console input device except SET, START 
RDR, and START WTR. 

Master command routine , which analyzes 
command verbs and routes control to 
appropriate command execution routines. 

Write-to-operator routine , which manages 
WTO buffers and requests console writes 
via the communication task wait routine. 

External interrupt routine , which 
switches to the alternate console device 
when an external interruption occurs. 


COMMUNICATION TASK CONTROL FLOW 

Commands are issued through either the 
console I/O device or the input reader (see 


Figure 11). Before entering commands 
through the console I/O device, the opera¬ 
tor must cause an I/O interruption. When 
he does, control is given to the supervisor 
which recognizes the interruption and pass¬ 
es control to the I/O supervisor. The I/O 
supervisor determines that the interruption 
is an attention signal and passes control 
to the master scheduler console interrupt 
routine. 


The console interrupt routine resides in 
the nucleus. It posts the attention ECB in 
the unit control module (UCM) and sets the 
attention flag in the UCM list entry cor¬ 
responding to the device from which the 
interrupt came. Posting of the attention 
ECB causes the communication task wait 
routine to be dispatched. 


The communication task wait routine 
waits on all communication ECBs associated 
with WTO/WTOR. The wait module issues a 
multiple wait macro-instruction on a list 
of event control blocks contained in the 
UCM. When one of the event control blocks 
is posted, as by attention or external 
interrupts, the wait is satisfied and the 
communication task thus becomes ready. 
When it becomes the active task, it issues 
the SVC 72. This SVC includes the console 
communication service routines and the 
router. 


Because the communication task serves a 
number of purposes, the first segment of 
SVC 72 is a routine that distinguishes 
among these purposes and establishes the 
order of response. This routine is called 
the router. The primary order of response 
is: external interruption, I/O completion, 
attention, and WTO(R). 


When a posted ECB is found by the 
router, the router XCTLs to the specified 
processor module. 

The console device processor routines 
perform reading and writing by using the 
EXCP macro-instruction. The processor rou¬ 
tines consist of a routine to service 
external interruption and three device- 
oriented routines: 1052 operator console 
routine, card reader routine, and printer 
routine. With each of the three console 
I/O processor routines is associated an 
OPEN/CLOSE support routine, which provides 
Data Management and I/O Supervisor control 
blocks. 

The specified processor routine reads 
the input message into a buffer area and 
calls the master command processor routine 
via an SVC. 
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Figure 11. Communication Task Control Flow 
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The master command processor routine 
analyzes the command for validity. Ten 
commands (REQ, START (blank), CANCEL, 
DISPLAY, MOUNT, STOP, UNLOAD, VARY, SHIFT 
and REPLY) are always accepted and process¬ 
ed. All other commands are ignored 
(control is returned to the supervisor) if 
issued at any time other than in response 
to a message issued by the master command 
routine. If the command is acceptable, it 
is moved from the buffer into which it was 
read to a local buffer, and control is 
passed to the master command routine. 


The master command routine analyzes com¬ 
mands and routes control to appropriate 
command execution routines. If a command 
is issued through the input job stream, 
control is passed directly to the master 
command routine by the reader/interpreter. 
When all commands have been entered and 
processed, control returns to the 
reader/interpreter. 

The write-to-operator routine moves the 
text from the requesting program's area 
into a buffer area within the nucleus and 
posts the communication ECB for write-to- 
operator. If the request was a WTOR, a 
message ID is generated and a reply queue 
entry is created to allow handling of the 
reply by the operator. 

The external interrupt routine assigns 
the functions performed by the primary 
console device to the alternate console 
device. When the operator presses the 
INTERRUPT key on the console, an external 
interruption occurs and control is given to 
the supervisor, which identifies the 
interruption and passes control to the 
external interrupt routine. The external 
interrupt routine then switches consoles 
and returns control to the supervisor. 
Console functions may later be reassigned 
to the primary console device if the opera¬ 
tor causes another external interrupt. 


CONSOLE INTERRUPT ROUTINE 

The console attention interrupt routine 
(Chart 04) POSTs the communication task 
attention ECB to request reading of the 
console. The routine is logically part of 
IOS. It operates in privileged mode, I/O 
interrupt disabled, without destroying the 
registers, and without macro access to 
supervisor services. Using the pointer to 
the UCB found in register 7, the UCB 
address is matched to a UCM entry. The 
attention flag for the entry is turned on. 
A branch entry to POST pointing at the 
attention ECB in the UCM, is then taken. 
Register 14 is used to return to IOS. 


COMMUNICATION TASK WAIT ROUTINE 

The communication task wait routine 
(Chart 07) issues a WAIT to the list of ECB 
addresses contained in the Event Indication 
List (EIL). The communication task is thus 
able to respond to a variety of events 
since the POSTing of any one ECB satisfies 
the wait. The POST issued in the console 
attention interrupt routine satisfies the 
wait, and results in the placement of the 
TCB on the ready queue. When next dis¬ 
patched, the wait routine issues an SVC 72 
which results in: (1) the creation of an 
SVRB; and (2) the fetching of the first 
segment of the console processor routines 
into the system transient area. 


COMMUNICATION TASK ROUTER 

The router (Chart 08), IEECVCTR, is the 
first segment of SVC 72 brought into the 
transient area. Since the communication 
task serves a number of purposes, and since 
service requests may be simultaneously 
pending, the router establishes the order 
of response. The primary order of treat¬ 
ment is external interrupt, I/O completion, 
attention (console interrupt), and WTO(R). 
Multiple attentions are treated in order of 
appearance in the UCM. Multiple I/O com¬ 
pletions are treated in order of first use 
of the device. The router responds to an 
attention by building a parameter list in 
the SVRB extended save area. It consists 
of a remote XCTL parameter list, a pointer 
to the appropriate UCM entry, and a pointer 
to the UCM (contents of CVTCUCB). The 
router then passes control to a processor 
routine by issuing an XCTL to the remote 
parameter list, using the name obtained 
from the UCB entry. The flag signifying 
the request to be serviced by the processor 
routine will be turned off by the processor 
routine. Consequently, processor routines 
return control to the router with XCTL to 
allow it to schedule service for other 
requests. 


If no requests are pending, the router 
exits to the wait routine using the address 
in register 14. 


In addition to distinguishing the output 
request from other requests, the router 
selects the particular device to which the 
message is to be sent. The router estab¬ 
lishes the output device by interrogating 
UCB entry attribute indicators. The 
appropriate entry is the first active entry 
that supports WTO. As before, the router 
builds a remote interface for, and passes 
control via XCTL to, a processor routine. 
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CONSOLE DEVICE PROCESSOR ROUTINES 

Control flow in a processor routine 
(Chart 10) is determined almost exclusively 
by the setting of flags in the router- 
selected UCM entry. The close flag is 
tested first. If this flag is on, any 
pending I/O activity is suspended by 
issuing a WAIT. An XCTL is then issued to 
an associated OPEN/CLOSE support routine 
for release of various control blocks. If 
the close flag is off, the busy flag is 
tested to determine I/O status. If there 
is outstanding I/O activity, error checking 
and buffer disposition occur if the activi¬ 
ty has been POSTed complete. Otherwise, 
any attention request is temporarily aban¬ 
doned (so are output requests), and an XCTL 
return to the router is taken. If the busy 
flag is off, the attention flag is tested, 
and if on, the status of the device is 
examined. If the device has not been 
opened, an XCTL to an associated OPEN/CLOSE 
support routine is issued for the purpose 
of obtaining core for a DCB and access- 
method dependent control blocks, and for 
execution of the OPEN macro. 


When return is made from the OPEN/CLOSE 
support routine, a response to the 
attention flag is prepared. A fixed buffer 
in the UCB is reserved and an access-method 
dependent interface is constructed. I/O 
activity is initiated by issuing EXCP for a 
1052, and by issuing a READ for a unit 
record device. In no case does the process 
routine await completion of this activity. 
Control is immediately returned to the 
router by issuing XCTL. 


Control flow within the processor rou¬ 
tine is as previously described up to the 
point at which the output request flag is 
tested. If on, the processor routine 
obtains the address of an output buffer 
from the UCM. The element is not removed 
from the queue at this time; this occurs 
only on successful completion of I/O. The 
reason is to preserve a natural method of 
having the message retried if an external 
interrupt intervenes before the message is 
successfully presented to the current 
device. Since output buffers are always 
selected from the top of the queue, the 
initiation of output to an alternate device 
would be unaffected by any previous 
attempts to present the message to the 
primary device. 

Having selected a buffer, the processor 
routine establishes data management and IOS 
control block linkages; and issues EXCP for 
a 1052, or WRITE for a printer. Without 
awaiting completion of the I/O, the proc¬ 
essor routine returns via XCTL to the 
router. 


MASTER COMMAND PROCESSOR ROUTINE 

The master command processor routine 
(Chart 05) processes the CANCEL, DISPLAY, 
MOUNT, REPLY, REQ, SHIFT, START (blank), 
STOP, UNLOAD, and VARY commands. It 
resides on the system residence device and 
is brought into the transient area of the 
nucleus by the supervisor when an SVC 34 
instruction is issued by the communication 
task or the master command routine. 

If the command is one of the ten pre¬ 
viously mentioned commands, it is processed 
by the SVC 34 routine. SET, START RDR, and 
START WTR commands are ignored unless they 
were issued in response to a message from 
the master command routine. If so, control 
is passed to the master command routine, 
which processes them. 

If entry to the master command processor 
routine was from the master command rou¬ 
tine, the command is available in a buffer 
(placed there by the master command 
routine). The command is processed. 

The master command processor routine 
returns control to the router. 


MASTER COMMAND ROUTINE 

The master command routine analyzes com¬ 
mand verbs and routes control to appropri¬ 
ate command execution routines. It also 
issues a message to the operator, informing 
him that commands will be accepted from the 
console. The master command routine is 
brought into main storage and entered when 
any of the following occur: 

• The reader/interpreter encounters a 
command in the input job stream. 

• The reader/interpreter is performing 
the initialization procedures that fol¬ 
low IPL. 

• The reader/interpreter finds the com¬ 
mand pending switch on. (The command 
pending switch is turned on by the 
routine that processes the REQ 
command.) 

• The reader/interpreter encounters an 
end-of-data set condition in the input 
job stream, indicating the end of a job 
step or job. Control is passed to the 
master command routine after the job 
step has been processed. 

Upon entry to the master command rou¬ 
tine, general register 0 is examined. If 
it contains zeros, entry was made because 
the reader/interpreter encountered a com¬ 
mand in the input job stream. The command 
is moved to the master command routine 
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buffer and is written out on the console 
output device for the operator's records. 
The command verb is then analyzed: if it is 
a SET, START RDR, or START WTR command, 
control is passed to an appropriate command 
execution routine. Otherwise, an SVC 34 
instruction is used to pass control to the 
master command EXCP routine. 

If general register 0 does not contain 
zeros upon entry to the master command 
routine, the IPL pending, new reader pend¬ 
ing, and new writer pending switches are 
checked. If any of these switches are on, 
the command pending switch is turned on and 
a message is issued requesting the operator 
to enter commands. Control is then passed 
to the initialization command routine, 
which provides certain commands, specified 
by the installation during system genera¬ 
tion (SYSGEN), to relieve the operator of 
entering initialization commands. Each of 
the commands provided is moved to the 
master command routine buffer, written on 
the console output device for the 
operator's records, and executed. 

If general register 0 does not contain 
zeros and none of the previously-mentioned 
pending switches are on, entry to this 
routine was made because the reader/inter¬ 
preter found the command pending switch on, 
or encountered an end-of-data set condition 
in the input job stream. A message is 
issued requesting commands from the opera¬ 
tor. After the operator has issued com¬ 
mands and they have been processed, control 
is returned to the reader/interpreter. 


WRITE-TO-OPERATOR ROUTINE 

The write-to-operator routine (Chart 06) 
writes operator messages on the console 
output device when a WTO or WTOR macro¬ 
instruction is issued. These macro¬ 
instructions may be issued by the system 
component programs and processing programs. 
Messages and replies are buffered; the 
period of time between the message and the 
reply is available for processing. 
Issuance of either macro-instruction causes 
an SVC interruption. When the interruption 
is handled, the supervisor has the routine 
read into the transient area of the nucleus 
and passes control to it. 

There are two console queues: the buffer 
queue and the reply queue. Each WTO and 
WTOR results in the addition of a WTO Queue 
Element (WQE) to the buffer queue, and each 
WTOR results in the addition of a Reply 
Queue Element (RPQE) to the reply queue. 
WTO and WTOR represent requests to present 
a message to the operator. SVC 35 sets up 
the user's messages and, if WTOR, inserts 
the message identification (ID) which the 
operator must use for his reply. The same 


message ID is placed in the RPQE with other 
information to insure passing the reply, 
when received, to the proper area. WTO 
messages are invariably written out; a WTOR 
message may be purged (removed from the 
queue) if the issuing task terminates while 
the message is on the buffer queue. There¬ 
fore, an RPQE differs from a WQE in that it 
contains the address of the issuing task's 
TCB. The buffer queue is accessed through 
the entry UCMWTOQ in the UCM. 

The reply queue contains RPQEs for oper¬ 
ator replies to WTOR. Elements in this 
queue, like WTOR elements in the buffer 
queue, contain a TCB address to permit 
purging. 

The extent of both queues is limited by 
specifying the number of buffers at system 
generation. An attempt to exceed a thres¬ 
hold value will result in an ENQ of the 
requesting task. 

For a reply (to WTOR), the processor 
issues SVC 34 (command processing). The 
SVC routine determines that the incoming 
command is in fact a reply, processes the 
reply, POSTs the user's ECB and branches 
back to the processor. 


EXTERNAL INTERRUPT ROUTINE 

The external interrupt routine (Chart 
04) switches to an alternate console device 
when the operator presses the INTERRUPT key 
on the console. This routine resides in 
the nucleus. 


SUPERVISOR MODIFICATIONS 
WAITR—SINGLE EVENT 

For the Option 2 system, the WAIT ser¬ 
vice routine also processes WAITR macro¬ 
instructions issued by a processing program 
to cause job management to be initiated in 
the next-lower-priority partition. If, 

when the routine is entered, the wait count 
is negative — i.e., has been complemented 
a WAITR has been issued. The routine 
determines whether the WAITR is the first 
that has been issued by the processing 
program. If the WAITR is not the first, or 
if the WAITR has been issued in the lowest- 
prior ity partition (from which no down 
shift is possible), the WAITR is treated as 
a WAIT with the same parameters. 

When a first WAITR is encountered and 
there is a next-lower-priority partition, 
the routine makes the task associated with 
that partition dispatchable. When that 
task is dispatched, job management routines 
are entered to cause a job to be scheduled 
into the partition. 
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When a first WAITR is serviced, a switch 
is set so that any subsequent WAITR issued 
in the same partition is treated as a WAIT. 
This switch is reset only upon termination 
of the job. 


NUCLEUS INITIALIZATION PROGRAM 

The primary change in the operation of 
NIP under control program Option 2 is that 
the standard partition initialization 
functions are repeated for each partition 
in the system. For each partition, just as 
for the single partition that exists with¬ 
out Option 2, a boundary box, a free area 
queue element, a PRB, and the required XCTL 
code are established. For a full explana¬ 
tion of the nucleus initialization program, 
including partition initialization, refer 
to IBM System/360 Operating System: Fixed- 
Task Supervisor, Program Logic Manual . 


ENQ/DEQ SUPPORT 

Enqueue Service Routine—IEAQENQO 

This routine (see Charts 19 through 22) 
is entered through a branch from a system 
routine, or from the SVC second-level 
interrupt handler in response to an ENQ 
(SVC 56). When the routine is entered, the 
major and minor QCBs are searched for 
existing control blocks representing the 
requested resource. If the required major 
and/or minor QCB are not found, the routine 
takes the action appropriate to the 
RET=parameter, as follows: 

• RET=TEST — the routine sets a return 
code of 00 (resource is available). 

• RET=USE or HAVE — the routine sets a 
return code of 00. The routine issues 
a GETMAIN and creates a queue element. 
A minor QCB or a minor and a major QCB 
is created if required.. 

• RET=NONE (or parameter left blank) 

no return code is set by the routine; 
control blocks are constructed as for 
RET=USE. 

When the required action is complete, the 
routine branches to the pre-exit subroutine 
described below, or begins again with the 
queue search if additional requests are to 
be processed. 

Pre-Exit Subroutine: This subroutine 

(TESTEND1 and TESTEND2 in CSECT IGC048) is 
entered to determine if the calling task 
can proceed. The task can always proceed 
if the RET=TEST parameter was used. Reg¬ 
ister 15 is set and control is returned to 
the task. If the SVRB wait count is not 
zero, the registers are saved in the TCB, 


the resume PSW is set to the address of the 
SMC test, the new PSW is set to zero, and 
the routine then branches to the dispatch¬ 
er. The return codes are set and control 
is returned to the calling task if the SVRB 
wait count is zero and must-complete is not 
requested. If must-complete is requested, 
the routine proceeds as described below. 

If the specified major QCB is found, the 
routine searches the major QCB's queue of 
minor QCBs for the specified minor name. 
If the minor QCB is not found, a return 
code is set and/or control blocks are 
created as explained above. If the minor 
QCB is found the queue elements queued on 
the minor QCB are searched for another 
queue element for the enqueueing task 
chained to the same minor QCB. Such a 
duplicate queue element indicates that the 
task has attempted to enqueue twice on the 
same resource without an intervening 
dequeue. If a duplicate request is encoun¬ 
tered, the routine causes the task to be 
abnormally terminated unless the new 
request is an inquiry (RET=HAVE, USE, or 
TEST). If the request is an inquiry, a 
return code of 08 is set and a subroutine 
is entered to determine whether the request 
includes a must-complete requirement. 

For a non-duplicate request, the routine 
determines whether all queue elements 
already enqueued on the minor QCB are 
"shared" and whether this is also a 
"shared" request. If both conditions are 
true, a queue element is created, the count 
field in the TCB (TCBCT) is incremented by 
one for each resource enqueued upon, and a 
return code is set and/or QCBs are created 
as explained above. 

If a queue element representing an 
"exclusive" request is already enqueued on 
the resource, the wait count in the SVRB 
associated with the new request is incre¬ 
mented by one. This wait count, which will 
be decremented by the dequeue service rou¬ 
tine when the exclusive request is satis¬ 
fied, causes the requesting task to wait in 
the enqueue routine but does not affect the 
dispatchability of the task as a whole. 
Asynchronous routines, called by IRBs added 
to the TCB's request block chain, can still 
operate under the task's control. 

The wait count is not incremented if the 
RET=USE parameter was included. In that 
case, the routine sets the "resource in 
use" return code and processes any further 
requests or proceeds to the pre-exit sub¬ 
routine. 

If must-complete was specified and the 
requesting task is a system task (rather 
than a user task, which would be abnormally 
terminated if 'set-must-complete' were 
specified), the subroutine sets on the 
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must-complete flag in the queue element and 
waits until any preceding requests on the 
queue have been dequeued. During this 
period the must-complete condition is not 
in effect. The flag in the queue element 
is set on to indicate that the condition is 
to be imposed, but only after use of the 
resource has actually begun. 

When the queue element containing the 
must-complete flag reaches the top of the 
resource queue — that is f when the 
resource becomes available to the task that 
requested the resource and the must- 
complete restriction — the step or system 
must-complete flag is set on in the task's 
TCB and all other TCBs in the system are 
made non-dispatchable. This ensures that 
the task that imposed the must-complete 
restriction will be the only task operating 
until the restriction is lifted, through 
issuance of a release-must-complete in that 
task. 

An exception arises if the system 
interrupt request block (SIRB) has been 
placed in the RB chain of another task. In 
that case, the task under which the SIRB is 
running is not set non-dispatchable, but a 
flag is set on in the exit routine of the 
supervisor's exit and transient area han¬ 
dler. The two tasks operate concurrently 
until the restriction is lifted by the 
responsible task (upon DEQ), or the task 
under which the SIRB is being serviced 
exits. Exit from the SIRB causes the task 
for which non-dispatchability was deferred 
to be set non-dispatchable. 

Dequeue Service Routine 

The dequeue service routine (see Charts 
23 through 25) is entered through the SVC 
second-level interrupt handler in response 
to a DEQ (SVC 48), or through a branch from 
a system routine. The function of the 
dequeue service routine is to remove from 
the list of pending requests a request that 
has been satisfied, and to cause the next 
request (if any) on the list to be ser¬ 
viced. In addition, the routine resets the 
must-complete condition when a reset is 
specified by a system task. 

After performing initial validity checks 
(Chart 26), the routine searches the major 
and minor QCB queues for the control blocks 
corresponding to the major and minor names 
specified by the requester. If the 
required QCBs are not found, the action 
taken is determined by the value of the 
RET=parameter: 

• If RET=HAVE, the request was condi¬ 
tional. A return code of 08 is set to 
indicate that the task in which the DEQ 
was issued was never enqueued upon the 
resource, and the routine proceeds to 


check for more parameter list entries 
to process. 


• If RET=NONE or the parameter was omit¬ 
ted, the task in which the DEQ was 
issued is abnormally terminated with an 
error code of 130. 

If the specified major QCB and minor QCB 
are found, the queue elements enqueued on 
the minor QCB are examined to determine 
whether a dequeue can be performed, and 
whether, if a dequeue cannot be performed, 
a return code is to be provided or the 
dequeueing task is to be abnormally termi¬ 
nated. 

A dequeue can be performed if the queue 
element enqueued by the task issuing the 
dequeue request is: 

• An exclusive request at the head of the 
queue, or 

• A shared request in any position 
preceding the first exclusive request 
on the queue. 

If either of those two conditions is met, 
the routine proceeds to dequeue the ele¬ 
ment. 

If these conditions are not met, there 
are two possibilities: either the queue 
element being sought by the dequeueing task 
is not in the queue, or it is in the queue 
but has never been serviced. If the queue 
element is not in the queue, the routine 
sets a return code of 08 and continues if 
RET=HAVE was specified, or abnormally ter¬ 
minates the dequeueing task. If the ele¬ 
ment is in the queue but has never been 
serviced, the routine: 

1. sets a return code of 04 and proceeds 
to the next item in the parameter list 
or 

2. abnormally terminates the task 

depending on the RET=parameter. The 04 
return code in this case indicates that the 
request was not at the top of the queue and 
is exclusive, or is shared but is preceded 
on the queue by an exclusive request. 

When a queue element to be dequeued is 
found, the count field in the TCB (TCBCT) 
is decremented by one and the queue element 
is removed from the queue. The TCBCT field 
is a record of the number of outstanding 
requests associated with the task. The 
count is incremented by 1 for each resource 
enqueued upon when the task issues an ENQ 
and decremented by 1 for each resource 
dequeued when a DEQ is issued by the task. 
This field is referred to, if the task is 
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abnormally terminated, to determine when 
all outstanding requests have been purged. 

If there are no more requests remaining 
on the minor QCB’s queue after the queue 
element is dequeued, the minor QCB itself 
is dequeued from the major QCB; similarly, 
if no additional minor QCBs remain, the 
major QCB is removed from the chain of 
major QCBs. A FREEMAIN is then issued, 
releasing the main storage formerly occu¬ 
pied by the removed control blocks. 

The presence of another queue element 
after the element removed through the DEQ 
means that the resource is now to be made 
available to the next enqueued task(s). If 
the next queue element represents an exclu¬ 
sive request, the DECSVRB subroutine is 
entered (see below) to enable the request¬ 
ing task to receive control. If the next 
queue element represents a shared request 
and the previous queue element was exclu¬ 
sive, the same function is performed not 
only for the task associated with the 
shared queue element, but for all subse¬ 
quent shared tasks in the queue as well, 
until the end of the queue or an exclusive 
request is reached. After preparing for 
the receipt of control by the necessary 
task or tasks, the routine frees the main 
storage used for any removed control blocks 
and proceeds. 

The DECSVRB subroutine (Chart 25) deals 
with a queue element that has just become 
the first element of the resource queue, or 
with a shared queue element not preceded by 
an exclusive request and therefore effec¬ 
tively at the top of the queue. The wait 
count in the SVRB associated with the queue 
element is examined. If the wait count is 
already zero (not the normal case), the 
subroutine exits. Otherwise, the wait 
count is decremented by one. If this does 
not reduce the wait count to zero, the 
enqueued task is still waiting for other 
resources and cannot, therefore, receive 
control; the subroutine exits. But if the 
wait count in the SVRB does reduce to zero, 
the enqueued task now has available to it 
all of the resources it requires and can 
receive control. A task switch is effected 
if the now-ready task is of higher priority 
than the task (pointed to by the NEW task 
control block address pointer in the com¬ 
munication vector table) last in control. 
If the enqueued task is of lower priority, 
no task switch occurs. In either case, 
however, the zero SVRB wait count makes it 
possible for the task to proceed when next 
dispatched. 

After the FREEMAIN operation for removed 
control blocks is complete, the routine 
loops back to process any further elements 
on the parameter list, or proceeds to reset 
must-complete (if required), check for 


return codes, and exit. Exit takes one of 
two paths: either to the caller (the task 
in which the DEQ was issued), or to the 
newly ready task (the task in which the ENQ 
was originally issued). If the contents of 
NEW have been changed by the dequeue rou¬ 
tine, the dispatcher performs the required 
task switch by giving control to the rou¬ 
tine in which the ENQ had been issued. 

Major and minor QCB's are moved to the 
partition represented by the next QEL when 
they reside in the partition that is issu¬ 
ing the DEQ. (See Figure 8.) 


DADSM MODIFICATIONS 

To provide volume table of contents 
(VTOC) integrity in a multi-task environ¬ 
ment, the DADSM allocate, extend, scratch, 
and release routines use the ENQ and DEQ 
macro-instructions and the must-complete 
options thereof to ensure that no task 
other than the task performing a VTOC 
update will access the VTOC while the 
update is in progress. The manner in which 
the ENQ and DEQ macro-instructions are used 
is summarized below. For further informa¬ 
tion on those routines, refer to the publi¬ 
cation IBM System/360 Operating System: 
Direct-Access Device Space Management, Pro¬ 
gram Logic Manual ; Form Y28-6607. 

Note: Except where specifically noted, the 
resource to which ENQ and DEQ requests 
relate is the VTOC for the volume upon 
which the DADSM routines are operating. 

Allocate Routines—Non-Indexed Sequential 
Data Sets 

On entry to the allocate routine, an ENQ 
is issued by the duplicate name search 
routine. The must-complete condition is 
subsequently set in (1) the sub-allocation 
routine, or (2) the DSCB creation routine. 
A DEQ is issued and the must-complete 
condition is reset in the VTOC updating 
routine. 

Allocate Routines—Indexed Sequential 
(ISAM) Data Sets 

An ENQ is issued by the duplicate name 
search routine. The must-complete condi¬ 
tion is set in either (1) the DSCB build 
routine, (2) the duplicate format 1 action 
routine, or (3) the embedded index routine. 
A DEQ is issued and the must-complete 
condition is reset by the completion of 
processing routine. 

If additional volumes are to be process¬ 
ed, an ENQ specifying the VTOC for the next 
volume is issued before the allocate rou¬ 
tines are re-entered for that volume. 
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Extend Routines 

An ENQ is issued and the must-complete 
condition is set by the duplicate name 
search routine. The VTOC updating issues a 
DEQ and resets the must-complete condition. 

Scratch Routine 

An ENQ is issued and the must-complete 
condition is set by the UCB search routine; 
DEQ is issued and the must-complete condi¬ 
tion is reset by the VTOC updating routine. 


This process is repeated on each pass 
through the routine for a multi-volume data 
set. 

Release Routine 

An ENQ is issued and must-complete con¬ 
dition is set by the first module of the 
release routine. DEQ is issued and must- 
complete condition is reset by the close 
routine of I/O Support, to which the 
release routine transfers control when VTOC 
updating is complete. 
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LOAD MODULES AND ASSEMBLY MODULES 


This section lists job management load 
modules and indicates the assembly modules 
that are processed by the linkage editor 
into each load module during system genera¬ 
tion. Included is a separate list that 
shows the load modules in which each 
assembly module is contained. 

Job management routines for MFT are 
packaged in three configurations: 18K, 
44K, and 100K (where K is 1024 bytes of 
main storage). The numbers represent the 
maximum amount of main storage occupied by 
job management routines and work areas at 
any time. All job management configura¬ 
tions function identically, but differ in 
both the number of load modules and the 
number of assembly modules within each load 
module. The configuration chosen at system 
generation determines the size of the low¬ 
est priority partition. 


LOAD MODULES 


In each configuration, all load modules 
are contained in three data sets: SYS1. 

NUCLEUS, SYS1•SVCLIB and SYS1.LINKLIB. 
These data sets also contain other parts of 
the control program. The load modules in 
the first two data sets remain the same for 
both job management configurations, but the 
SYS1.LINKLIB data set contains a different 
set of load modules for each configuration, 
depending on which one was selected at 
system generation time. In the 18K config¬ 
uration, LINKLIB contains 52 load modules; 
in the 44K configuration, it contains 38 
load modules; and in the 100K configura¬ 
tion, it contains 36 load modules. 

Charts 27, 28, and 29 show the control 
flow among load modules. The decision to 
transfer control (XCTL) to a particular 
succeeding load module is made in the 
previous load module. Each subsequent 
module loaded in response to an XCTL macro 
instruction is read into main storage 
directly over the previous load module. 
Such load modules are read into the low- 
numbered end of the partition in which job 
scheduling is being performed. 

Modules that are brought into storage 
with LINK macro instructions and LOAD macro 
instructions occupy separate storage areas 
within the partition; such modules are 
shown on the control-flow charts. Because 
storage is used in this manner, the load 

I module lists may be used with charts 27, 
28, or 29 to determine the approximate 
layout of a partition at different times 


during the execution of job management 
routines. Other items present in the par¬ 
tition at the same time as the load modules 
are not shown on the control flow charts 
because, although these items are neces¬ 
sary, control is not passed among them. 
They are, generally, the tables and control 
blocks, work areas, access methods, buf¬ 
fers, and register save areas. 

In the following load module lists, 
entry points are shown if a load module 
contains more than one assembly module. If 
only one assembly module is named, the 
entry point is the same as the assembly 
module's control section (CSECT) name given 
in the Assembly Modules and Control Sec¬ 
tions table in this section. 


LOAD MODULES CONTAINED IN THE SYS1.NUCLEUS 
DATA SET 


The load modules and assembly modules in 
the following list are contained in the 
SYS1.NUCLEUS data set, and are always pres¬ 
ent in the nucleus, or system area of main 
storage, regardless of the job management 
configuration. 


Load Module Name: IEANUC01 

As s ernbly Modul es: 

IEEBClPE External interrupt routine. 

IEECIR01 Console interrupt routine. 

IEERSC01 Master scheduler buffers, 

switches, input/output block 
(IOB), event control block 
(ECB), channel control word 
(CCW), and device end block 
(DEB). This load module forms 
master scheduler resident main 


storage in the nucleus area when 
the primary or alternate console 
(1052) is used. 

IEERSR01 Master scheduler buffers, 

switches, IOB, ECB, CCW, and 
DEB. This load module forms 
master scheduler resident main 
storage in the nucleus area when 
the composite console is used. 

IEFDPOST Unsolicited-interrupt routine. 

MCONRESA Table store subroutine work 


IEECVCRX 

IEECVCRA 

IEECVUCM 


area. 

External Interrupt Routine (MFT) 
Console Interrupt Routine (MFT) 
Communication Task buffers, 
switches, input/output blocks 
(IOB), event control blocks 
(ECB), data extent blocks (DEB), 
and data control blocks (DCB). 
This data area is used for 
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operator communication in MFT 
systems. 

IEECVPRG Operator communication reply 
queue purging routine (MFT). 
IEECVCTW Communication Task Wait Module. 


LOAD MODULES CONTAINED IN THE SYS1.SVCLIB 
DATA SET 

The load modules and assembly modules in 
the following list are contained in the 
SYS1.SVCLIB data set, and are called in 
response to SVC instructions. 


Load Module Name: IGC0I07B 
Assembly Module: 

IEECVOCX MFT Console unit initialization 
EXCP input/output. 


Load Module Name: IGC1I07B 
Assembly Module: 

IEECVOCC MFT Console unit initialization 
BSAM input. 


Load Module Name: IGC2IQ7B 
Assembly Module: 

IEECVOCP MFT Console unit initialization 
BSAM output. 



Load Module Name: IGC0003D 

Assembly Modules: 

IEEMXC01 Master command EXCP routine 

(Part 1) — primary/alternate 
console. 

IEEMXR01 Master command EXCP routine 

(Part 1) — composite console. 

IEEMCP01 MFT Master Command EXCP routine 
(overlay module). 


Load Module Name; IEE1203D 
Assembly Module: 

IEE1203D MFT Master Command Reply Proces¬ 
sor (overlay module). 


Load Module Name: IGC0007B 
Assembly Module: 

IEECVCTR Communication Task Router 

module. 


Load Module Name: IGC0107B 
Assembly Module: 

IEECVPMX MFT Communication Task Process 
module — access method EXCP 
(1052). 


Load Module Name: IGCXL07B 
Assembly Module: 

IEECVCTX MFT Communication Task external 
interrupt processor. 


Load Module Name: IGC0Q03E 
Assembly Modules: 

IEEWTC01 Write-to-operator (WTO) routine 

-- primary/alternate console. 
IEEWTR01 Write-to-operator (WTO) routine 
-- composite console. 

IEECVWTO MFT WTO/WTOR queueing routine. 


Load Module Name: IGCQ103D 
Assembly Module: 

IGC0103D Master command EXCP routine 

(Part 2), or command processing 
routine. 

IGC0113D MFT Master Command EXCP routine 
(overlay module). 


Load Module Name: IGC0QQ3F 
Assembly Module: 

IEEBH1PE Not used in sequential schedul¬ 
ing system. 



Load Module Name: IGC1107B 
Assembly Module: 

IEECVPMC MFT Communication Task Process 
module — access method BSAM 
(2540). 


Load Module Name: IGC2107B 
Assembly Module: 

IEECVPMP MFT Communication Task Process 

module — access method BSAM 

(1443). 


MODULES CONTAINED IN THE SYS1.LINKLIB DATA 
SET 


The load modules and assembly modules in 
the following lists are contained in the 
SYSl•LINKLIB data set. A list is provided 
for both of the packaging configurations in 
which job management routines are 
available. 
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18K CONFIGURATION 


( 


Load Module Name: IEECVCTI 
Entry Point: IEECVCTI 
Assembly Modules: 

IEECVCTI MFT Communication Task Initiali¬ 
zation routine. 

IEEVRFRX MFT CVT # TCB, RB, TIOT, and UCB 
look-up module. 

Load Module Name: GO 
Alias: IEFKl 

Alias: IEFSD030 

Entry Point: IEFSD036 
Assembly Modules: 

IEFSDO36 Rearranges partition boundaries. 

IEFSDO34 Pre-termination (exits to 

IEFSD011). 

IEFDNSFT Scheduler downshift routine* 
IEFQMSSS Table store subroutine. 

IEFSDO06 Converts record number to logi¬ 

cal track address (TTR). 

IEFSDO07 Call to table store subroutine. 

Load Module Name: IEFSTERM 
Alias: IEFYN 

Alias: IEFSD011 

Entry Point: IEFSD011 
Assembly’Modules: 

IEFSDO11 Entry to job management from 

supervisor. 

IEFW42SD Passes control to IEFIDUMP (in 
IEFIDUMP Load Module) if neces¬ 
sary, or to IEFYNIMP (in this 
module). 

IEFYNIMP Step termination routine. 
IEFYPJB3 Step data set driver routine. 

IEFVJIMP Job statement condition code 

IEFZGST1 Disposition and unallocation 
subroutine. 

IEFACTLK Linkage to user's accounting 
routine. 

IEFACTRT Dummy, to be replaced by user's 
accounting routine. 

IEFWAD Writes accounting information to 
data set SYS1.ACCT. 

(The preceding three modules may be re¬ 
placed by IEFACTFK assembly module if no 
accounting routine is specified as a system 
generation option.) 

IEFSDO17 Places logical track address 

(TTR) of first system message 
block (SMB) into job control 
table (JCT). 

IEFW22SD Passes control to IEFYNIMP (in 
this load module), then to 
IEFSD002 (in this load module) 
or to IEFZAJB3 (in IEFJTERM load 
module) . 

IEFSD002 Exit to IEF08FAK or IEF09FAK 
(both in this load module). 
IEFSDO06 Converts record number to logi¬ 

cal track address (TTR). 


IEFSD007 Call to table store subroutine. 

IEFYSSMB Message enqueuing routine, 

enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFVJMSG Contains initiator/terminator 
messages. 

IEFYNMSG Contains initiator/terminator 
messages. 

IEFYPMSG Contains initiator/terminator 
messages. 

IEFZGMSG Unallocation and message writing 
routine. 

IEFZHMSG Contains initiator/terminator 
messages. 

IEFIDFAK Linkage to IEFIDUMP (in IEFIDUMP 
load module). 

IEFZAFAK Linkage to IEFZAJB3 (in IEFJTERM 
load module). 

IEF08FAK Linkage to IEFSDO08 (in IEFINTFC 
load module). 

IEF09FAK Linkage to IEFSD009 (in IEFSELCT 
load module). 

Load Module Name: IEFSELCT 
Alias: IEFSD009 

Entry Point: IEFSD009 
Assembly Modules: 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFSD009 Initializes initiator/ 
terminator. 

IEFSD094 IBM supplied job separator 
routine. 

IEFSD095 IBM supplied job separator 
routine. 

IEFSD088 IBM supplied job separator 
routine. 

IEFSD089 IBM supplied job separator 
routine. 

IEFSEPAR Dummy user separator routine. 
IEFSD059 Interface to separator routines. 
IEFSGOPT System generation option 
indicators. 

IEFACTLK Linkage to user's accounting 
routine. 

IEFACTRT Dummy, to be replaced by user's 
accounting routine. 

IEFWAD Writes accounting information to 

data set SYS1.ACCT. 

(The preceding three modules may be re¬ 
placed by IEFACTFK assembly module if no 
accounting routine is specified as a system 
generation option.) 

IEFW21SD System control routine. 

IEFVKIMP Execute statement condition code 
routine. 

IEFVMLS1 JFCB housekeeping (H/K) control 
routine. 

IEFVM2LS JFCB H/K fetch DCB routine. 
IEFVM3LS JFCB H/K generation data group 
(GDG) single routine. 
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IEFVM4LS JFCB H/K generation data group 
(GDG) all routine. 

IEFVM5LS JFCB H/K patterning data set 

control block (DSCB) routine. 

IEFVM76 Processes passed, non-labeled 

tape data sets. 

IEFWSTRT Job started and job termination 
message routine. 

IEFYSSMB Message enqueuing routine, 

enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFWMAS1 Device name table. 

IEFVKMSG Contains initiator terminator 

messages. 

IEFVMLK5 Linkage to IEFVMLS6 (in IEFERROR 
load module). 

IEFXAFAK Linkage to IEFXCSSS (in IEFALOCl 
load module). 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 


Load Module Name: IEFALOCl 
Alias: IEFXJ000 

Alias: IEFXA 

Entry Point: IEFXA 
Assembly Modules: 

IEFXCSSS Allocation control routine. 

IEFXJIMP Allocation error recovery 

routine. 

IEFYSSMB Message enqueuing routine. 
IEFQMSSS Table store subroutine. 

IEFXAMSG Contains initiator/terminator 
messages. 

IEFXJMSG Contains initiator/terminator 
messages. 

IEFWAFAK Linkage to IEFWAOOO (in IEFAL0C2 
load module). 

IEFWCFAK Linkage to IEFWCIMP (in IEFAL0C3 
load, module) . 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

Load Module Name: IEFAL0C2 
Alias: IEFWAOOO 

Entry Point: IEFWAOOO 
Assembly Modules: 

IEFWAOOO Demand allocation routine. 

IEFWSWIN Passes control to decision allo¬ 

cation or automatic volume rec¬ 
ognition (AVR) routine. 

IEFX5FAK Linkage to IEFX5000 (in load 
module IEFX5000). 

IEFX300A Device strikeout routine. 
IEFWMSKA Device mask table. 

IEFWCFAK Linkage to IEFWCIMP (in IEFAL0C3 

load module). 

IEFXJFAK Linkage to IEFXJIMP (in IEFALOC1 
load module). 

IEFS15XL Check for duplicate allocation. 

IEFSD006 Converts record number to logi¬ 

cal track address (TTR). 

IEFSGOPT System generation option 
indicators. 


IEFXVFAK Linkage to IEFXV001 (in load 
module IEFALOC4). 

Load Module Name: IEFALQC3 
Alias: IEFWC000 

Entry Point: IEFWC000 
Assembly Modules: 

IEFWCIMP Task Input/Output Table con¬ 
struction routine. 

IEFXH000 Separation strikeout routine. 

IEFWDFAK Linkage to IEFWD000 (in IEFAL0C4 

module). 

IEFXJFAK Linkage to IEFXCSSS (in IEFALOCl 
module). 

Load Module Name: IEFALOC4 
Alias: IEFWD000 

Entry Point: IEFWD000 
Assembly Modules: 

IEFWD000 External action routine. 

IEFWD001 Message directory for external 
action routine. 

IEFXKIMP Allocation error non-recovery 
routine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMB's. 

IEFQMSSS Table store subroutine. 

IEFXKMSG Contains initiator/terminator 
messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFXTFAK Linkage to IEFXT000 (in load 
module IEFALOC5). 

IEFXV001 Automatic volume recognition. 
IEFXVNSL AVR volume serial routine. 

IEFXVMSG AVR message routine. 

IEFX1FAK Linkage to IEFXJIMP (in load 
module IEFALOCl). 

IEFX2FAK Linkage to IEFX5000 (in load 
module IEFX5000). 

IEFX3FAK Linkage to IEFWCIMP (in load 
module IEFALOC3). 

IEFX300A Device strikeout routine. 
IEFS15XL Check for duplicate allocation. 

Load Module Name: IEFALOC5 
Alias: IEFXT000 

Entry Point: IEFXT000 
Assembly Modules: 

IEFXKIMP Allocation error non-recovery 
routine. 

IEFXTDMY Queue overflow routine. 

IEFXT00D Space request routine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFXKMSG Contains initiator/terminator 
messages. 

IEFXTMSG Contains initiator/terminator 
messages. 

IEFW41SD Exit to IEF04FAK (in this load 
module). 


/T^\ 
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IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEF04FAK Linkage to IEFSD004 (in IEFATACH 
load module). 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

IEFWDFAK Linkage to IEFWD000 (in IEFALOC4 
load module)- 

Load Module Name: IEFX5Q00 
Entry Point: IEFX5000 
Assembly Modules: 

IEFX5000 Decision allocation routine. 

IEFXJFAK Linkage to IEFXJIMP (in IEFAL0C1 

load module). 

IEFXH000 Separation strikeout routine. 
IEFX300A Device strikeout routine. 
IEFWCFAK Linkage to IEFWCIMP (in IEFALOC3 
load module). 

IEFS15XL Check for duplicate allocation. 

Load Module Name: IEFATACH 
Alias: IEFSD004 

Entry Point: IEFSD004 
Assembly Modules: 

XEFSD004 Step initiation routine, with 
exit to processing program. 
IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFSD007 Call to table store subroutine. 
IEFSD010 Dequeues and writes out system 
message blocks (SMBs). 

IEFQMSSS Table store subroutine. 

Load Module Name: IEFCNTRL 

Alias: IEFVHAA 

Alias: IEFVHCB 

Alias: IEFVHF 

Alias: IEFVHA 

Entry Point: IEFVHA 

Assembly Modules: 

IEFDAFAK Linkage to IEFVDA (in IEFDD load 
module). 

IEFEAFAK Linkage to IEFVEA (in IEFEXEC 

load module). 

IEFHMFAK Linkage to IEF7KPXX (in IEFCOMMD 

load module). 

IEFJAFAK Linkage to IEFVJA (in IEFJOB 

load module). 

IEFKGDUM Linkage to IEF7KGXX (in IEFINTFC 

load module). 

IEFVFA Interpreter scan routine. 

IEFVGMSS Builds interpreter error system 

message blocks (SMBs). 

IEFVHA Performs input stream or PROCLIB 

I/O. 

IEFVHAA Sets reader end-of-file (EOF) 

conditions. 

IEFVHB Generates DD * statement for 

data in the input stream. 

IEFVHC Checks input for valid 

continuation. 

IEFVHCB Identifies control statement 

verbs and performs procedure 


modification. 

IEFVHE Job router routine. 

IEFVHEB Pre-scan routine. 

IEFVHEC Enqueues job request. 

IEFVHF Post-processing control routine. 

IEFVHGSS DD * error routine. 

IEFVHH Sets up tables for queuing and 

provides initiator/terminator 
interface. 

IEFVHL Null statement processing 

routine. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes operator error messages. 

IEFQMSSS Table store subroutine. 

IEFVFB Generates SYSIN DD *, if 

necessary. 


Load Module Name: IEFDD 
Alias: IEFVDA 

Entry Point: IEFVDA 
Assembly Modules: 

IEFHFFAK Linkage to IEFVHF (in IEFCNTRL 
load module). 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 
IEFSD090 Assigns unit for system output 
(SYSOUT). 

IEFSD012 DD * statement routine. 

IEFVDA DD card scan routine. 

IEFVGI Interpreter Dictionary Entry 

Routine. 

1EFVGK Obtains parameter from internal 

table built by IEFVFA. 

IEFVGMSS Builds interpreter error system 
message blocks (SMBs) . 

IEFVGS Interpreter Dictionary Search 

routine. 

IEFVGT Checks validity of control card 

parameters. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes operator error messages. 

IEFVDDUM Prevents unresolved IEFVDBSD 
symbol. 

IEFQMSSS Table store subroutine. 

Load Module Name: IEFINTFC 

Alias: IEFSD008 

Alias: IEFSD001 

Alias: IEFKG 

Entry Point: IEFSD008 

Assembly Modules: 

IEEILCDM Prevents unresolved IEEICCAN 

symbol after initialization. 
IEEMCS01 Master command routine. 

IEFHCBFK Linkage to IEFVHCB (in IEFCNTRL 

load module). 

IEFSD001 Reader/interpreter entry to 

IEF09FAK or to IEF23FAK. 
IEFSD006 Converts record number to logi¬ 

cal track address (TTR). 
IEFSD007 Call to table store subroutine. 

IEFSD008 Initiator/terminator to reader/ 

interpreter interface. 


Load Modules and Assembly Modules 41 



Form Y27-7128-0 Page Revised by TNL Y27-7157 12/12/67 


Load Modules Load Modules 

(18K Configuration, Continued) (18K Configuration, Continued) 


IEF09FAK Linkage to IEFSD009 (in IEFSELCT 
load module). 

IEF23FAK Linkage to IEFW23SD (in IEFJTERM 
load module). 

IEF7KGXX Interpreter-Initiator Interface 

Module. 

IEFHAFAK Linkage to IEFVHA (in IEFCNTRL 

load module). 

IEFQMSSS Table Store Subroutine. 

IEFVHQ Table Store Interface routine. 

IEFHAAFK Linkage to IEFVHAA (in IEFCNTRL 

load module). 

IEFVHRSS Writes operator operator error 

messages. 

IEECNDUM Prevents unresolved external 

reference to IEECN01. 


Load Module Name: IEFEXEC 
Alias: IEFVEA 

Entry Point: IEFVEA 
Assembly Modules: 

IEFHFFAK Linkage to IEFVHF (in IEFCNTRL 

load module). 

IEFVEA EXEC card scan routine. 

IEFVGK Obtains parameter from internal 

table built by IEFVFA. 

IEFVGMSS Builds interpreter error system 

message blocks (SMBs). 

IEFVGS Interpreter Dictionary Search 

Routine. 

IEFVGT Checks validity of control card 

parameters. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes operator error messages. 

IEFVGI Interpreter Dictionary Entry 

Routine. 

IEFQMSSS Table Store Subroutine. 

Load Module Name: IEFJOB 
Alias: IEFVJA 

Entry Point: IEFVJA 
Assembly Modules: 

IEFHFFAK Linkage to IEFHFPAK (in IEFCNTRL 
load module). 

IEFVGK Obtains keyword from internal 

table built by IEFVFA. 

IEFVGMSS Builds interpreter error system 

message blocks (SMBs). 

IEFVGT Checks validity of control card 

parameters. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes operator error messages. 

IEFVJA Job card scan routine. 

IEFQMSSS Table Store Subroutine. 

Load Module Name: IEFJTERM 
Alias: IEFW23SD 

Alias: IEFZA 

Entry Point: IEFZA 
Assembly Modules: 

IEFW23SD Initializes for job termination, 
exits to IEFZAJB3 (in this load 
module). 


IEFZAJB3 Job termination routine. 

IEFWTERM Job ended message routine. 

IEFZGJB1 Disposition and unallocation 

subroutine. 

IEFACTLK Linkage to user's accounting 
routine. 

IEFACTRT Dummy module to be replaced by 
user's accounting routine. 

IEFWAD Writes accounting information to 

data set SYS1.ACCT. 

(The preceding three modules may be re¬ 
placed by IEFACTFK assembly module if no 
accounting routine is specified as a system 
generation option.) 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFSD007 Call to table store subroutine. 

IEFYSSMB Message enqueuing routine, 

enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFZHFAK Call to ZP0QMGR1 subroutine, in 
IEFZGJBl of this load module. 
IEFZGMSG Contains initiator terminator 
messages. 

IEFZHMSG Unallocation and message writing 
routine. 

IEFW31SD Exit to IEFSD003 (in this load 
module). 

IEFSD003 Passes control to 1EFSD010, then 
to IEF08FAK, (both in this load 
module). 

IEFSD010 Dequeues and writes out system 
message blocks (SMBs). 

IEFSD035 Check for downshift (exit to 
IEFSD031). 

IEF08FAK Linkage to IEFSD008 (in IEFINTFC 
load module). 

Load Module Name: IEFCQMMD 
Alias: IEFVHM 

Entry Point: IEFVHM 
Assembly Modules: 

IEEILCDM Prevents unresolved IEEICCAN 
symbol after initialization. 
IEEMCS01 Master command routine. 

IEFHAAFK Linkage to IEFVHAA (in IEFCNTRL 
load module). 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFVGMSS Builds interpreter error system 
message blocks (SMBs) . 

IEFVHQ Table store interface routine. 

IEF7KPXX Command in the input stream 
routine. 

IEFHAFAK Linkage to IEFVHA (in IEFCNTRL 
load module). 

IEFVHRSS Writes operator messages. 
IEFQMSSS Table store subroutine. 

IEECNDUM Prevents unresolved external 
reference to IEEICN01. 

Load Module Name: IEFERROR 
Alias: IEFVM6LS 

Entry Point: IEFVMSGR 
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Assembly 

IEFVMLS6 

IEFYSSMB 

IEFQMSSS 

IEFVMLS7 

IEFYNFAK 


Modules: 

JFCB housekeeping error message 
processing routine. 

Message enqueuing routine, 
enqueues SMBs. 

Table store subroutine. 

Contains initiator/terminator 
messages 

Linkage to IEFYNIMP (in IEFSTERM 
load module). 


Load Module Name: 1EFVGM9 
Assembly Module: 

IEFVGM9 Contains reader/interpreter 
messages. 


Load Module Name: IEFVGM10 
Assembly Module: 

IEFVGM10 Contains reader/interpreter 
messages. 


Load Module Name: IEFIDUMP 

Entry Point: IEFIDUMP 

Assembly Modules: 

IEFIDUMP Indicative dump routine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFIDMPM Contains initiator/terminator 
messages 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 


Load Module Name: IEFVGMl1 
Assembly Module: 

IEFVGM11 Contains reader/interpreter 
messages. 


Load Module Name: IEFVGM12 
Assembly Module: 

IEFVGM12 Contains reader/interpreter 
messages. 


Load Module Name: IEFVGMl 
Assembly Module: 

IEFVGMl Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM2 
Assembly Module: 

IEFVGM2 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM3 
Assembly Module: 

IEFVGM3 Contains reader/interpreter 

messages * 

Load Module Name: IEFVGM4 
Assembly Module: 

IEFVGM4y Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM5 
Assembly Module: 

IEFVGM5 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM6 
Assembly Module: 

IEFVGM6 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM7 
Assembly Module: 

IEFVGM7 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM8 
Assembly Module: 

IEFVGM8 Contains reader/interpreter 

messages. 


Load Module Name: IEFVGMl3 
Assembly Module: 

IEFVGM13 Contains reader/interpreter 
messages. 


Load Module Name: IEFVGMl4 
As s embly Modu1e: 

IEFVGMl4 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGMl5 
Assembly Module: 

IEFVGM15 Contains reader/interpreter 
messages. 

Load Module Name: IEFVGMl6 
Assembly Module: 

IEFVGMl6 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGMl7 
Assembly Module: 

IEFVGMl7 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGMl8 
Assembly Module: 

IEFVGMl8 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM70 
Assembly Module: 

IEFVGM70 Contains reader/interpreter 
messages. 

Load Module Name: IEFVGM78 
Assembly Module: 

IEFVGM78 Contains reader-interpreter 
messages. 
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Load Module Name: IEFINITL 

Alias: IEFVHN 

Entry Point: IEFKl 

Assembly Modules: 

IEEILC01 Automatic command routine. 

IEFPRFAK Linkage to IEFPRES load module. 

IEFQMSSS Table store subroutine. 

IEFSGOPT System generation option 

indicators. 

IEFSD006 Converts record number to logi¬ 

cal track address (TTR). 

IEFSD007 Call to table store subroutine. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes error messages to 

operator. 

IEFVH1 Interpreter Work Area (IWA) 

initialization routine. 

IEFVH2 Opens input reader and procedure 

libraries. 

IEFWSDIP Linkage Control Table (LCT) 

initialization routine. 

IEF7KIXX Entry to job management from 

nucleus initialization program 
(NIP). 


IEEMCS01 

IEFVHN 

IEF7K2XX 

IEF7K3XX 

IEEVSMDM 

IEEICN01 


Master Command routine. 
Interpreter termination routine. 
PCP dependent reader/interpreter 
initialization. 

Reader/interpreter exit routine. 
Prevents unresolved external 
reference to IEEVMSG. 

Converts SYSOUT writer JFCB 
record numbers to TTRs. 


Load Module Name: IEFPRES 
Assembly Modules: 

IEFPRES Volume attribute initialization 
routine. 

IEFK1MSG Reader/Interpreter message 
routine. 


Load Module Name: IEESET 
Alias: IEEGESTO 

Assembly Module: 

IEEGES01 Master scheduler SET command 
routine. 


Load Module Name: IEFJOBQE 
Alias: IEFINTQS 

Assembly Modules: 

IEFINTQA Initializes SYS1.SYSJOBQE data 
set. 

IEFSGOPT System generation option 
indicators. 


Load Module Name: IEETIME 
Alias: IEEQOTOO 

Assembly Module: 

IEEQOTOO Sets time and date. 


Load Module Name: IEEFAULT 
Alias: IEEGK1GM 

Assembly Module: 

IEEGK1GM Fault routine — issues master 
scheduler messages. 


Load Module Name: IEESTART 
Alias: IEEIC1PE 

Entry Point: IEEIC1PE 
Assembly Modules: 

IEESTART START command routine. 

IEEREADR Start reader routine. 

IEEWRITR Start writer routine. 


Load Module Name: IEEJFCB 
Alias: IEEIC3JF 

Assembly Module: 

IEEIC3JF Contains preformatted JFCB for 
one START command. 


Load Module Name: IEESJFCB 
Alias: IEEIC2NQ 

Entry Point: IEEIC2NQ 
Assembly Modules: 

IEEIC2NQ Saves START command JFCBs. 

IEFQMSSS Table store subroutine. 

Load Module Name: IEFSD031 
Entry Point: IEFSD031 
Assembly Modules: 

IEFSD031 Scheduler upshift routine 

IEFSD006 Converts record number to logi¬ 

cal track address (TTR). 

IEFSD007 Call to table store subroutine 
IEFQMSSS Table store subroutine 

Load Module Name: IEFPRINT 
Alias: SPRINTER 

Alias: IEFPRT 

Assembly Module: 

IEFPRTXX Tape SYSOUT to printer or punch. 

Load Module Name: IEFBR14 
Assembly Module: 

IEFBR14 Branch 14. 


44 


Form Y27-7128-0 Page Revised by TNL Y27-7157 


12/12/67 


44K CONFIGURATION 


Load Module Name; IEECVCTI tion of output unit, passes con- 

Entry Point: IEECVCTI trol to IEFW21SD (in this load 

Assembly Modules: module). 


IEECVCTI MFT Communication Task Initiali¬ 
zation routine. 

IEEVRFRX MFT CVT, TCB, RB, TIOT, and UCB 
look-up module. 

Load Module Name: GO 
Alias: IEFKl 

Alias:; IEFSD030 
Entry Point: IEFSD036 
Assembly Modules: 

IEFSD036 Rearranges partition boundaries. 
IEFSD034 Pre-termination (exits to 

IEFSD011). 

IEF'DNSFT Scheduler downshift routine. 
IEFQMSSS Table store subroutine. 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFSD007 Call to table store subroutine. 

Load Module Name: IEFSTERM 
Alias: IEFYN 

Alias: IEFSD009 

Alias: IEFSD011 

Entry Point: IEFSD011 
Assembly Modules: 

IEFSD011 Entry to job management from 
supervisor. 

IEFW42SD Passes control to IEFIDUMP (in 

IEFIDUMP load module) if indica¬ 
tive dump is needed, or to 
IEFYNIMP (in this load module). 
IEFYNIMP Step termination routine. 
IEFYPJB3 Step data set driver routine. 

IEFVJIEP JOB statement condition code 

routine. 

IEFZGST1 Disposition and unallocation 
subroutine. 

IEFACTLK Linkage to user's accounting 
routine. 

IEFACTRT Dummy user's accounting routine. 

IEFWAD Writes accounting information to 

data set SYS1.ACCT. 

(The preceding three modules may be re¬ 
placed by IEFACTFK assembly module if no 
accounting routine is specified as a system 

generation option.) 

IEFSD017 Places logical track address 

(TTR) of first system message 
block (SMB) in job control table 
(JCT). 

IEFW22SD Passes control to IEFYNIMP (in 

this load module), and then to 
IEFSD002 (in this load module) 
or to IEFZAJB3 (in IEFCNTRL load 
module). 

IEFSD002 Exit to IEF08FAK or IEFSD009 

(both in this load module). 
IEFSD009 Initiator/terminator initializa- 


IEFSD094 IBM supplied job separator 
routine. 

IEFSD095 IBM supplied job separator 
routine. 

IEFSDO88 IBM supplied job separator 
routine. 

IEFSD089 IBM supplied job separator 
routine. 

IEFSEPAR Dummy user separator routine. 

IEFSD059 Interface to separator routines. 

IEFSGOPT System generation option 
indicators. 

IEFW21SD System control routine. 

IEFVKIMP EXEC statement condition code 

routine. 

IEFVMLS1 JFCB housekeeping control 
routine. 

IEFVM2LS Fetch DCB routine. 

IEFVM3LS GDG single routine. 

IEFVM4LS GDG all routine. 

IEFVM5LS Patterning DSCB routine. 

IEFVM76 Processes passed nonlabeled tape 
data sets. 

IEFWSTRT Job started and job termination 

message routine. 

IEFWMAS1 Device name table. 

IEFSDO06 Converts record number to logi¬ 

cal track address (TTR). 

IEFSD007 Call to table store subroutine. 

IEFYSSMB Message enqueuing routine, 

enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFVJMSG Contains initiator/terminator 

messages. 

IEFVKMSG Contains initiator/terminator 

messages. 

IEFYNMSG Contains initiator/terminator 

messages. 

IEFYPMSG Contains initiator/terminator 

messages. 

IEFZGMSG Contains initiator/terminator 

messages. 

IEFZHMSG Unallocation and message writing 
routine. 

IEFIDFAK Linkage to IEFIDUMP (in IEFIDUMP 
load module). 

IEFVMLK5 Linkage to IEFVMLS6 (in IEFERROR 
load module). 

IEFXAFAK Linkage to IEFXCSSS (in IEFALOC1 
load module). 

IEFZAFAK Linkage to IEFZAJB3 (in IEFCNTRL 
load module). 

IEF08FAK Linkage to IEFSD008 (in IEFCNTRL 
load module). 

Load Module Name: IEFALQC1 

Alias: IEFXA 

Entry Point: IEFXA 


Load Modules and Assembly Modules 45 



Form Y27-7128-0 Page Revised by TNL Y27-7157 12/12/67 


Load Modules 

(44K Configuration, Continued) 


Assembly Modules: 

IEFXCSSS Allocation control routine. 

IEFWA000 Demand allocation routine. 

IEFWSWIN Passes control to decision allo¬ 

cation or AVR routine. 

IEFXJIMP Allocation error recovery 
routine. 

IEFX300A Device strikeout routine. 

IEFYSSKB Message enqueuing routine. 

IEFQKSSS Table store routine. 

IEFXAMSG Contains initiator/terminator 
messages. 

IEFXJMSG Contains initiator/terminator 
messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

IEFX5FAK Linkage to IEFX5000 (in IEFAL0C2 
load module). 

IEFWCFAK Linkage to IEFWCOOO (in IEFALOC2 
load module). 

IEFS15XL Check for duplicate allocation. 

IEFWMSKA Device Mask Table. 

IEFXV001 Automatic Volume Recognition. 

IEFXVNSL AVR volume serial routine. 

IEFXVMSG AVR message routine. 

IEFWD000 External action routine. 

IEFWD001 Message directory for external 
action routine. 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFXKIMP Allocation error nonrecovery 
routine. 

IEFXKMSG Contains initiator/terminator 
messages. 

IEFXTFAK Linkage to IEFXT00D (in IEFAL0C2 
load module). 

IEFSGOPT System generation option 
indicators. 

Load Module Name: IEFAL0C2 

Alias: IEFX5000 

Alias: IEFWCOOO 

Entry Point: IEFX5000 

Assembly Modules: 

IEFXH000 Separation strikeout routine. 

IEFXJMSG Contains initiator/terminator 

messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

IEFYSSMB Message enqueuing routine. 

IEFQMSSS Table store routine. 

IEFXJIMP Allocation error recovery 

routine. 

IEFX5000 Decision allocation routine. 

IEFX300A Device strikeout routine. 

IEFWCIMP Task Input/Output Table (TIOT) 

construction routine. 

IEFWD000 External action routine. 

IEFWD001 Message directory for external 

action routine. 

IEFSD006 Convert record number to logical 
track address (TTR). 

IEFXTOOD Space request routine. 

IEFXTMSG Contains initiator/terminator 


Load Modules 

(44K Configuration, Continued) 


messages. 

IEFXTDMY Queue overflow routine. 

IEFXKIMP Allocation error non-recovery 
routine. 

IEFXKMSG Contains initiator/terminator 
messages. 

IEFW41SD Exit to step initiation routine. 

IEFSD004 Step initiation routine with 

exit to processing program. 
IEFSD007 Call to table store routine. 
IEFSD010 Dequeue and write out system 
message blocks (SMBs) . 

IEFXAFAK Linkage to IEFXCSSS (in IEFALOCl 
load module). 

IEFS15XL Check for duplication 
allocation. 

Load Module Name: IEFCNTRL 

Alias: IEFVHA 

Alias: IEFVHAA 

Alias: IEFSD008 

Alias: IEFKG 

Alias: IEFZA 

Entry Point: IEFVHA 

Assembly Modules: 

IEFSD035 Check for downshift (exit to 

IEFSD031). 

IEFVDA DD card scan routine. 

IEFVEA EXEC card scan routine. 

IEFVFA Interpreter scan routine. 

IEFVGI Interpreter Dictionary Entry 

Routine. 

IEFVGK Interpreter Get Parameter 

Routine. 

IEFVGMSS Builds interpreter error system 

message blocks (SMBs). 

IEFVGS Interpreter Dictionary Search 

Routine. 

IEFVGT Interpreter Test and Store 

Routine. 

IEFVHA Performs input stream or PROCLIB 

I/O. 

IEFVHAA Sets reader end-of-file (EOF) 

conditions. 

IEFVHB Generates DD * stateraent for 

data in the input stream. 

IEFVHC Checks input for valid 

continuation. 

IEFVHCB Identifies control statement 

verbs and performs procedure 
modification. 

IEFVHE Job router routine. 

IEFVHEB Pre-scan routine. 

IEFVHEC Enqueues job request. 

IEFVHF Post-processing control routine. 

IEFVHGS3 DD * error routine. 

IEFVHH Sets up tables for queuing and 

provides initiator/terminator 
interface. 

IEFVHL Null statement processing 

routine. 

IEFSD010 Dequeues and writes out system 

message blocks (SMBs). 

IEFVHQ Table store interface routine. 


C' 
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Load Modules 

(44K Configuration, Continued) 


IEFVHRSS Writes error messages to 
operator. 

IEFVJA Job card scan routine. > 

IEFW23SD Initializes for job termination 
and exits to IEFZAJB3 (in this 
load module). 

IEFZAJB3 Job termination routine. 

IEFWTERM Job ended message routine. 

IEFZGJBl Disposition and unallocation 

subroutine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMBs. 

TEFZHFAK Call to ZP0QMGR1 subroutine, in 
IEFZGJBl (in IEFJTERM load 
module). 

IEFW31SD Job termination exit to 
IEFSD003. 

IEFSD003 Passes control to IEFSD010, and 
then goes to IEFSD008. 

IEFQMSSS Table store subroutine. 

IEF7KGXX Output tables for step. 

IEFSD008 Initiator/terminator to reader/ 

interpreter interface. 

IEFSD001 Reader/interpreter entry to 
IEFSD009 or to IEFW23SD. 

IEFSD007 Call to table store subroutine. 
IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFZGMSG Contains initiator/terminator 
messages. 

IEFZHMSG Unallocation and message writing 

routine. 

IEF09FAK Linkage to IEFSD009 (in IEFSELCT 

load module). 

IEFVDDUM Prevents unresolved IEFVDBSD 

symbol. 

IEFSD090 Assign unit for system output 

(SYSOUT). 

IEFSD012 DD * statement routine. 

IEFHMFAK Linkage to IEF7KPXX (in 1EFCOMMD 

load module). 

IEEMCRFK Linkage to IEEMCREP (in IEFCOMMD 

load module). 

IEFVFB Generates SYSIN DD *, if 

necessary.' 

IEFACTLK Linkage to user’s accounting 

routine. 

IEFACTRT Dummy routine to be replaced by 

user's accounting routine. 

IEFWAD Writes accounting information to 

data set, SYS1.ACCT. 

(The preceding three modules may be re¬ 
placed by IEFACTFK assembly module if no 
accounting routine is specified as a system 
generation option.) 


Load Module Name: IEFCOMMD 
Alias: IEFVHM 

Alias: IEEMCREP 

Entry Point: IEFVHM 
Assembly Modules: 

IEEMCS01 Master Command Routine. 

IEF7KPXX Command in the input stream 

routine. 


Load Modules 

(44K Configuration, Continued) 

IEFVGMSS Builds system messages blocks 
(SMBs). 

IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 

IEFHAAFK Linkage to IEFVHAA (in IEFCNTRL 
load module). 

IEFHAFAK Linkage to IEFVHA (in IEFCNTRL 
load module). 

IEFVHRSS Writes error messages to 
operator. 

IEEILCDM Prevents unresolved IEEICAN sym¬ 
bol after initialization. 

IEFVHQ Table store interface routine. 

IEFQMSSS Table store subroutine, 

IEEMCREP Links to IEEMCR01 and returns to 

IEF7KGXX (in the IEFCNTRL load 
module). 

IEECNDUM Prevents unresolved external 
reference to IEEICN01. 

Load Module Name: IEFERROR 
Alias: IEFVM6LS 

Entry Point: IEFVMSGR 
Assembly Modules: 

IEFVMLS6 JFCB housekeeping error message 

processing routine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMBs. 

IEFQMSSS Table store subroutine. 

IEFVMLS7 Contains initiator/terminator 
messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 

load module). 

Load Module Name: IEFIDUMP 
Entry Point: IEFIDUMP 
Assembly Modules: 

IEFIDUMP Indicative dump routine. 

IEFYSSMB Message enqueuing routine, 
enqueues SMBs. 

IEFQMSSS ' Table store subroutine. 

IEFIDMPM Contains initiator/terminator 

messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSTERM 
load module). 

Load Module Name: IEFVGM1 
Assembly Module: 

IEFVGMl Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM2 
Assembly Module: 

IEFVGM2 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM3 
Assembly Module: 

IEFVGM3 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM4 
Assembly Module: 

IEFVGM4 Contains reader/interpreter 

messages. 
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Load Modules 

(44K Configuration, Continued) 


Load Module Name: IEFVGM5 
Assembly Module: 

IEFVGM5 Contains reader/interpreter 
messages. 


Load Modules 

(44K Configuration, Continued) 


Load Module Name: IEFVGM18 
Assembly Module: 

IEFVGM18 Contains reader/interpreter 
messages. 



Load Module Name: IEFVGM6 
Assembly Module: 

IEFVGM6 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM7 
Assembly Module: 

IEFVGM7 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM8 
Assembly Module: 

IEFVGM8 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM9 
Assembly Module: 

IEFVGM9 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM10 
Assembly Module: 

IEFVGM10 Contains reader/interpreter 
messages. 

Load Module Name: IEFVGM11 
Assembly Module: 

IEFVGM11 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM12 
Assembly Module: 

IEFVGM12 Contains reader/interpreter 
messages. 

Load Module Name: IBFVGM13 
Assembly Module: 

IEFVGM13 Contains reader/interpreter 

messages. 

Load Module Name: 1EFVGM14 
Assembly Module: 

IEFVGM14 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM15 
Assembly Module: 

IEFVGM15 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM16 
Assembly Module: 

IEFVGM16 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM17 
Assembly Module: 

IEFVGM17 Contains reader/interpreter 

messages. 


Load Module Name: IEFVGM7Q 
Assembly Module: 

IEFVGM70 Contains reader/interpreter 
messages. 

Load Module Name: IEFVGM78 
Assembly Module: 

IEFVGM78 Contains reader/interpreter 
messages. 


Load Module Name: IEFINITL 

Alias: IEFVHN 

Entry Point: IEFK1 

Assembly Modules: 

IEF7K1XX Entry to job management from 

nucleus initialization program 
(NIP). 

IEEMCS01 Master command routine. 

IEFPRES Volume attribute initialization 

routine. 

IEFK1MSG Reader/interpreter message 

routine. 

IEEILC01 Automatic command routine. 

IEFWSDIP Linkage control table (LCT) 

initialization. 

IEFSD006 Converts record number to logi¬ 

cal track address (TTR). 

IEFQMSSS Table store subroutine. 

IEFSD007 Call to table store subroutine. 

IEFVH1 Interpreter Work Area (IWA) 

initialization routine. 

IEFVH2 Opens input reader and procedure 

library. 

IEFVHN Interpreter Termination Routine. 

IEFVHQ Table store interface routine. 

IEFVHRSS Writes error messages to 

operator. 

IEFSGOPT System generation option 

indicators. 

IEF7K3XX Reader/interpreter exit routine. 

IEF7K2XX PCP dependent reader/interpreter 

initialization. 

IEEVSMDM Prevents unresolved external 

symbol for IEEVSMSG. 

IEEICN01 Converts SYSOUT writer JFCB 

record numbers to TTRs. 


Load Module Name: IEESET 
Alias: IEEGESTO 

Assembly Module: 

IEEGES01 Master scheduler SET command 
routine. 

Load Module Name: IEFJOBQE 
Alias: IEFINTQS 

Assembly Module: 

IEFINTQA Initializes SYS1.SYSJOBQE data 
set. 


/TA 
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Load Modules 

C44K Configuration, Continued) 


IEFSGOPT System generation option 
indication. 

Load Module Name: IEETIME 
Alias: IEEQOTOO 

Assembly Module: 

IEEQOTOO Sets time and date. 

Load Module Name: IEEFAULT 
Alias: IEEGK1GM 

Assembly Module: 

IEEGK1GM Fault routine, issues master 
scheduler messages. 

Load Module Name: IEESTART 
Alias: IEEIC1PE 

Entry Point: IEEIC1PE 
Assembly Modules: 

IEESTART START command routine. 

IEEREADR Start reader routine. 

IEEWRITR Start writer routine. 

Load Module Name: IEEJFCB 
Alias: IEEIC3JF 

Assembly Module: 

XEEIC3JF Contains preformatted JFCB for 

one START command. 


Load Modules 

(44K Configuration, Continued) 


Load Module Name: IEESJFCB 
Alias: IEEIC2NQ 

Entry Point: IEEIC2NQ 
Assembly Modules: 

IEEIC2NQ Save JFCBs for START commands. 
IEFQMSSS Table store subroutine. 


Load Module Name: IEFSD031 
Entry Point: IEFSD031 
Assembly Modules: 

IEFSD031 Scheduler upshift routine. 
IEFSD006 Converts record number to logi¬ 
cal track address (TTR). 
IEFSD007 Call to table store subroutine. 
IEFQMSSS Table store subroutine. 


Load Module Name: IEFPRINT 
Alias: SPRINTER 

Alias: IEFPRT 

Assembly Module: 

IEFPRTXX Tape SYSOUT to printer or punch. 

Load Module Name: IEFBR14 
Assembly Module: 

IEFBR14 Branch 14. 


100K CONFIGURATION 


Load Module Name: IEECVCTI 
Entry Point: IEECVCTI 
Assembly Modules: 

IEECVCTI MFT Communication Task Initiali¬ 
zation routine. 

IEEVRFRX MFT CVT, TCB, RB, TIOT, and UCB 
look-up module. 

Load Module Name: GO 
Alias: IEFKl 

Alias: IEFSD030 

Entry Point: IEFSD036 
Assembly Modules: 

IEFSDO36 Rearranges partition boundaries. 
IEFSD034 Pre-termination (exits to 

IEFSDO11). 

IEFDNSFT Scheduler downshift routine. 
IEFQMSSS Table store subroutine. 

IEFSDO06 Converts record number to logi¬ 

cal track address (TTR). 

IEFSDO07 Call to table store subroutine. 

Load Module Name: IEFSD011 

Alias: IEFXA 

Alias: IEFSDO08 

Alias: IEFYN 

Alias: IEFVHA 

Entry Point: IEFSDO11 


Assembly Modules: 

IEFSD011 Entry to job management from 
supervisor. 

IEFW42SD Passes control to IEFIDUMP if 

needed, or tc IEFYNIMP (botn in 
this load module). 

IEFYNIMP Step termination routine. 

IEFYPJB3 Step data set driver routine. 

IEFVJIMP JOB statement condition code 

routine. 

IEFZGSTl Disposition and unallocation 
subroutine. 

IEFSD017 Places logical track address of 
first system message block (SMB) 
into job control table (JCT). 

IEFW22SD Passes control to IEFYNIMP 

assembly module, and then to 
IEFSD002 or IEFZAJB3 (all in 
this load module). 

IEFSD002 Exit to IEFSD008 or to IEFSD009 
(both in this load module). 

IEFSD008 Initiator/terminator to reader/ 
interpreter interface. 

IEFSD012 DD * statement routine. 

IEF7KPXX Command in input stream routine. 

IEEMCS01 Master command routine. 

IEF7KGXX Output tables for step. 
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Load Modules Load Modules 

(100K Configuration, Continued) (100K Configuration, Continued) 


IEFSDO 01 Reader/interpreter entry to 

IEFSD009 or to IEFW23SD (both in 
this load module). 

IEFSDO09 Initiator/terminator initializa¬ 

tion of output unit. 

IEFW21SD System control routine. 

IEFSDO35 Check for downshift (exit to 

IEFSD031). 

IEFSGOPT System generation option 
indicators. 

IEFXKFAK Linkage to IEFXK0 00 (in IEFALERR 
load module). 

IEECNDUM Prevents unresolved external 
reference to IEEICN01. 

IEFSDO94 IBM-supplied separators for 

classes A and B. 

IEFSDO95 IBM-supplied separators for 

classes A and B. 

IEFSDO88 IBM-supplied separators for 
classes A and B. 

IEFSDO89 IBM-supplied separators for 
classes A and B. 

IEFSEPAR Dummy separator routine. 

IEFSDO59 Linkage to separator routines. 

IEFVFB Macro capability. 

IEFSI5XL Checks for duplicate allocation. 

IEFSDO90 Assign unit for system output 

(SYSOUT). 

IEFVDA DD card scan routine. 

IEFVEA Exec card scan routine. 

IEFVFA Interpreter scan routine. 

IEFVGI Interpreter Dictionary Entry 

Routine. 

IEFVGK Interpreter get parameter 

routine. 

IEFVGMSS Builds interpreter error system 

message blocks (SMBs). 

IEFVGS Interpreter dictionary search 

routine. 

IEFVGT Interpreter Test and Store 

Routine. 

IEFVHA Performs input stream or PROCLIB 

I/O. 

IEFVHAA Sets reader end-of-file (EOF) 

conditions. 

IEFVHB Generates DD * for data in the 

input stream. 

IEFVHC Checks input for valid 

continuation. 

IEFVHCB Identifies control statement 

verbs and performs procedure 
modification. 

IEFVHE Interpreter Router Routine. 

IEFVHEB Pre-scan routine. 

IEFVHEC Enqueues job request. 

IEFVHF Post-processing control routine. 

IEFVHGSS DD * error routine. 

IEFVHH Sets up tables for queuing and 

provides initiater/terminator 
interface. 

IEFVJA Job card scan routine. 

IEFVHL Null statement processing 

routine. 

IEFVHQ Table store interface routine. 


IEFVHRSS Writes error messages to 
operator. 

IEFVDDUM Prevents unresolved IEFVDBSD 
symbol. 

IEFIDFAK Linkage to IEFIDUMP (in IEFIDUMP 
load module). 

IEFVKIMP EXEC statement condition code 
routine. 

IEFVMLS1 JFCB housekeeping (H/K) control 
routine. 

IEFVM2LS JFCB H/K fetch DCB routine. 

IEFVM3LS JFCB H/K generation data group 
(GDG) single routine. 

IEFVM4LS JFCB H/K generation data group 
(GDG) all routine. 

IEFVM5LS JFCB H/K patterning data set 
control block (DSCB) routine. 

IEFXJFAK Linkage to IEFXJ000 (in IEFALERR 
load module). 

IEFWCIMP Task Input/Output Table (TIOT) 
construction routine. 

IEFWD000 External action routine. 

IEFWD001 Message directory for external 

action routine. 

IEFVMLS6 JFCB H/K error message process¬ 
ing routine. 

IEFVM76 Processes passed, non-labeled 

tape data sets. 

IEFWSTRT Job started and job termination 

message routine. 

IEFWMASl Device name table. 

IEFXCSSS Allocation control routine. 

IEFWA000 Demand allocation routine. 

IEFWSWIN Passes control to decision allo¬ 

cation or AVR routine. 

IEFXV001 Automatic volume recognition. 

IEFXVNSL AVR volume serial routine. 

IEFXVMSG AVR message routine. 

IEFX5000 Decision allocation routine. 

IEFX300A Device strikeout routine. 

IEFXH000 Spearation strikeout routine. 

IEFWMSKA Device mask table. 

IEFXT00D Space request routine. 

IEFXTDMY Queue overflow routine. 

IEFW41SD Exit to step initiation routine. 

IEFSD004 Step initiation routine, with 

exit to processing program. 

IEFW23SD Initializes for job termination 

and exits to IEFZAJB3 (in this 
load module). 

IEFZAJB3 Job termination routine. 

IEFWTERM Job ended message routine. 

IEFZGJBI Disposition and unallocation 

subroutine. 

IEFACTLK Linkage to user's accounting 

routine. 

IEFACTRT Dummy routine to be replaced by 

user's accounting routine. 

IEFWAD Writes accounting information to 

a data set, SYS1.ACCT. 

(The preceeding three modules may be re¬ 
placed by IEFACTFK assembly module if no 

accounting routine is specified as a system 

generation option.) 
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Load Modules 

(10OK Configuration, Continued) 

IEFW31SD 

Job termination exit to 

IEFSD003. 

IEFSD003 

Passes control to IEFSD010 and 
then goes to IEFSD008 (both in 
this load module). 

IEFSD010 

Dequeues and writes out system 
message blocks (SMBs). 

IEFYSSKB 

Message enqueuing routine, 
enqueues SMBs. 

IEFSD0 06 

Converts record number to logi¬ 
cal track address (TTR). 

IEFSD007 

Call to table store subroutine. 

IEFQMSSS 

Table store subroutine. 

IEE1LCDM 

Prevents unresolved IEEICAN sym¬ 
bol after initialization (Job 
management IPL). 

IEFVJMSG 

Contains initiator/terminator 
messages. 

IEFVKMSG 

Contains initiator/terminator 
messages. 

IEFVMLS7 

Contains initiator/terminator 
messages. 

IEFXAMSG 

Contains initiator/terminator 
messages. 

IEFXTMSG 

Contains initiator/terminator 
messages. 

1EFYNMSG 

Contains initiator/terminator 
messages. 

IEFYPMSG 

Contains initiator/terminator 
messages. 

IEF2.GMSG 

Contains initiator/terminator 
messages. 

IEFZHMSG 

Unallocation and message writing 
routine. 

Load Module Name: IEFVGM1 


Assembly Modules 

IEFVGM1 Contains reader/interpreter 

messages. 

Load Module Name; IEFVGM2 

Assembly Module: 

IEFVGM2 Contains reader/interpreter 

messages. 

Load Module Names IEFVGM3 

Assembly Modules 

IEFVGM3 Contains reader/interpreter 

messages. 

Load Module Names IEFVGM4 

Assembly Module: 

IEFVGM4 Contains reader/interpreter 

messages. 

Load Module Names IEFVGM5 

Assembly Modules 

IEFVGM5 Contains reader/interpreter 

messages. 

Load Module Names IEFVGM6 

Assembly Modules 

IEFVGM6 Contains reader/interpreter 

messages. 


Load Modules 

(100K Configuration, Continued) 


Load Module Name: IEFVGM7 
Assembly Module: 

IEFVGM7 Contains reader/interpreter 

messages. 

Load Module Names IEFVGM8 
Assembly Module: 

IEFVGM8 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM9 
Assembly Module: 

IEFVGM9 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM1Q 
Assembly Module: 

IEFVGM10 Contains reader/interpreter 
messages. 

Load Module Name: 1EFVGM11 
Assembly Module: 

IEFVGMll Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM12 
Assembly Module: 

IEFVGM12 Contains reader/interpreter 
messages. 

Load Module Names IEFVGM13 
Assembly Module: 

IEFVGM13 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM14 
Assembly Module: 

IEFVGM14 Contains reader/interpreter 
messages. 

Load Module Names IEFVGM15 
Assembly Module: 

IEFVGM15 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM16 
Assembly Module: 

IEFVGM16 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM17 
Assembly Module: 

IEFVGM17 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM18 
Assembly Module: 

IEFVGM18 Contains reader/interpreter 

messages. 

Load Module Name: IEFVGM70 
Assembly Module: 

IEFVGM70 Contains reader/interpreter 

messages. 
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Load Modules Load Modules 

(100K Configuration, Continued) (100K Configuration, Continued) 


Load Module Name: IEFVGM78 
Assembly Module: 

IEFVGM78 Contains reader/interpreter 
messages. 

Load Module Name: IEFINITL 
Alias: IEFVHN 
Entry Point: IEFK1 
Assembly Modules: 

IEF7K1XX Intial entry to job management 

from nucleus initialization pro¬ 
gram (NIP). 

IEFPRES Volume attribute initialization 
routine. 

IEFK1MSG Reader/interpreter message 
routine. 

IEEMCS01 Master command routine. 

IEE1LC01 Automatic command routine. 
IEFWSDIP Linkage control table (LCT) 
initialization. 

IEFSDO06 Converts record number to logi¬ 

cal track address (TTR). 

IEFSDO07 Call to table store subroutine. 

IEFQMSSS Table store subroutine. 

IEF7K3XX Input stream end-of-file (EOF) 

routine. 

IEFVHN Interpreter Termination routine. 

IEFVHQ Table store interface routine. 

IEFVH1 Interpreter Initialization 

routine. 

IEFVH2 Opens input stream and procedure 

library data set. 

IEFSGOPT System generation option 
indicators. 

IEFHAFAK Linkage to IEFVHA (in IEFSD011 
load module). 

IEFVHRSS Writes error messages to the 
operator. 

IEF7K2XX PCP Reader/Interpreter system 
dependent initialization. 
IEEVSMDM Prevents unresolved external 
reference to IEEVSMSG. 

IEEICN01 To convert record numbers to 
TTR 1 s for writers other than 
class A. 

Load Module Name: IEFIDUMP 
Entry Point: IEFIDUMP 
Assembly Modules: 

IEFIDUMP Indicative dump routine. 

IEFYSSMB Message enqueuing routine. 
IEFQMSSS Table store subroutine. 

IEFIDMPM Contains initiator/terminator 
messages. 

IEFYNFAK Linkage to IEFYNIMP (in IEFSD011 
load module). 

Load Module Name: IEFALERR 
Alias: IEFXJ000 
Alias: IEFXK000 
Entry Point: IEFXJ000 
Assembly Modules: 

IEFXJIMP Allocation error recovery 
routine. 


IEFXJMSG Contains initiator/terminator 
messages. 

IEFXAFAK Linkage to IEFXCSSS (in IEFSD011 
load module). 

IEFYNFAK Linkage to IEFYNIMP (in IEFSD011 
load module). 

IEFYSSMB Message enqueuing routine. 

IEFXKIMP Allocation error non-recovery 
routine. 

IEFXKlviSG Contains initiator/terminator 
messages. 

IEFQMSSS Table store routine. 

Load Module Name: IEESET 

Alias: IEEGESTO 

Assembly Modules: 

IEEGES01 Master scheduler SET command 
routine. 


Load Module Name: IEFJOBQE 
Alias: IEFINTQS 

Assembly Module: 

IEFINTQA Initializes SYS1.SYSJOBQE data 
set. 

IEFSGOPT System generation option 
indicators. 


Load Module Name: IEETIME 
Alias: IEEQOTOO 

Assembly Module: 

IEEQOTOO Sets time and date in response 
to SET command. 


Load Module Name: IEEFAULT 
Alias: IEEGK1GM 

Assembly Modules: 

IEEGK1GM Fault routine, issues master 
scheduler messages. 

Load Module Name: IEESTART 
Alias: IEEIC1PE 

Entry Point: IEEIC1PE 
Assembly Modules: 

IEESTART V START command routine. 

IEEREADR Start reader routine. 

IEEWRITR Start writer routine. 

Load Module Name: IEEJFCB 
Alias: IEEIC3JF 

Assembly Module: 

IEEIC3JF Contains preformatted JFCB for 
one START command. 

Load Module Name: IEESJFCB 
Alias: IEEIC2NQ 

Entry Point: IEEIC2NQ 
Assembly Modules: 

IEEIC2NQ Save START command JFCB. 
IEFQMSSS Table store subroutine. 

Load Module Name: IEFSDO31 
Entry Point: IEFSD031 
Assembly Modules: 

IEFSD031 Scheduler upshift routine. 
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Load Modules 

(100K Configuration, Continued) 


IE-FSDO06 Converts record numbers to logi¬ 

cal track address (TTR). 

IEFSD007 Call to table store subroutine. 
IEFQMSS Table store subroutine. 

Load Module Name: IEFPRINT 
Alias: SPRINTER 

Alias: IEFPRT 


Load Modules 

(100K Configuration, Continued) 


Assembly Module: 

IEFPRTXX Transfers tape system output 
(SYSOUT) to printer or punch. 


Load Module Name: IEFBR14 
Assembly Module: 

IEFBR14 Branch 14. 
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ASSEMBLY MODULES AND CONTROL SECTIONS 


The following table shows in which load 
modules each assembly module is used in the 
three configurations of job management. 
The first column lists the assembly module 
names in alphameric order. Except as indi¬ 
cated, all assembly modules are contained 
in load modules in the SYS1.LINKLIB data 
set. The second column lists the control 
section names that correspond to the 


assembly module names in the first column. 
The next three columns of the table indic¬ 
ate which load modules of each configura¬ 
tion contain each assembly module. The two 
right-hand columns refer to the CHARTS 
section. If a control section is shown as 
a subroutine block, the flowchart number is 
listed in the "Appears As Subr. Block" 
column; if the flow within a control sec¬ 
tion is given in a chart, the flowcnart 
number is listed in the "Flow is Defined" 
column. 


• Assembly Modules and Control Sections (Part 1 of 6) 
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• Assembly Modules and Control Sections (Part 2 of 6) 
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• Assembly Modules and Control Sections (Part 3 of 6) 
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• Assembly Modules and 
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Control Sections (Part 4 of 6) 
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1 

1 

1 

1 

1 

Control 
Section Name 

| Load Modules in Which 

j Assembly Modules are Used 

L 

r i 

| 18K 

44K | 

_ 4 

100K 


t 

T 


T ' “ ' 1 

1 



1 

1 


| IEFEXEC 




1 

1 


j IEFJOB 



IEFVHA 

1 

1 

IEFVHA. 

j IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHAA 

1 

1 

IEFVHAA 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHB 

1 

1 

IEFVHB 

j IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHC 

1 

1 

IEFVHC 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHCB 

1 

1 

IEFVHCB 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHE 

1 

1 

IEFVHE 

j IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHEB 

1 

1 

IEFVHEB 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHEC 

1 

1 

IEFVHEC 

j IEFCNTRL 

IEFCNTRL 

IEFSD011 

XEFVHF 

1 

1 

IEFVHF 

| IEFCNTRL 

IEFCNTRL 

IEF3D011 

IEFVHGSS 

1 

1 

IEFVHG 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHH 

1 

1 

IEFVHH 

j IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHL 

1 

1 

IEFVHL 

| IEFCNTRL 

IEFCNTRL 

IEFSD011 

IEFVHN 

1 

1 

IEFVHN 

j IEFINITL 

IEFINITL 

IEFINITL 

IEFVHQ 

1 

1 

IEFVHQ 

| IEFINTFC 

IEFCNTRL 

IEFSD011 


1 

1 


j IEFCNTRL 

IEFCOMMD 

IEFINITL 


1 

1 


j IEFDD 

IEFINITL 



1 

! 


| IEFEXEC 




1 

1 


j IEFJOB 




1 

1 


j IEFCOMMD 




1 

1 


j IEFINITL 



IEFVHRSS 


1 

IEFVHR 

j IEFINTFC 

IEFCNTRL 

IEFSD011 


1 

1 


\ IEFCNTRL 

IEFCOMMD 

IEFINITL 


1 

1 


| IEFDD 

IEFINITL 



1 

1 


f IEFEXEC 




i 

1 


| IEFJOB 




1 

1 


j IEFCOMMD 




1 

1 


| IEFINITL 



1EFVH1 

1 

1 

IEFVH1 

[ IEFINITL 

IEFINITL 

IEFINITL 

IEFVH2 

1 

1 

IEFVH2 

[ IEFINITL 

| IEFINITL 

IEFINITL 

IEFVJA 

1 

1 

IEFVJA 

| IEFJOB 

IEFCNTRL 

. IEFSDOll 

IEFVJIMP 

1 

1 

IEFVJ 

| IEFSTERM 

. IEFSTERM 

IEFSD011 

IEFVJMSG 

1 

1 

IEFVJMSG 

t IEFSTERM 

| IEFSTERM 

IEFSDOll 

IEFVKIMP 

1 

1 

IEFVK 

| IEFSELCT 

: IEFSTERM 

! IEFSDOll 

IEFVKMSG 

1 

1 

IEFVKMSG 

1 IEFSELCT 

1 IEFSTERM 

IEFSDOll 

IEFVMLK5 

1 

f 

IEFVM6 

| IEFSELCT 

i IEFSTERM 


IEFVMLS1 

1 

1 

IEFVM1 

\ IEFSELCT 

[ IEFSTERM 

IEFSDOll 

IEFVMLS6 

1 

1 

IEFVM6 

j IEFERROR 

| IEFERROR 

IEFSDOll 

IEFVMLS7 

1 

1 

IEFVM7 

j IEFERROR 

1 IEFERROR 

IEFSDOll 

IEFVM2LS 

1 

1 

IEFVM2 

( IEFSELCT 

, IEFSTERM 

IEFSDOll 

IEFVM3LS 

1 

1 

IEFVM3 

j IEFSELCT 

IEFSTERM 

IEFSDOll 

IEFVM4LS 

1 

1 

IEFVM4 

j IEFSELCT 

IEFSTERM 

IEFSDOll 

IEFVM5LS 

1 

1 

IEFVM5 

| IEFSELCT 

[ IEFSTERM 

IEFSDOll 

IEFVM76 

1 

1 

IEFVM76 

j IEFSELCT 

IEFSTERM 

IEFSDOll 

IEFWAD 

1 

1 

IEFWAD 

| IEFSTERM 

t IEFSTERM 

IEFSDOll 


1 

1 


| IEFJTERM 

IEFCNTRL 



1 

1 


j IEFSELCT 



IEFWAFAR 

1 

1 

IEFWA000 

| IEFALOCl 



IEFWA000 

1 

1 

IEFWA7 

1 IEFALOC2 

IEFALOCl 

IEFSDOll 

IEFWCFAK 

1 

1 

IEFWCIMP 

| IEFALOCl 

j IEFALOCl 



1 

1 


j IEFALOC2 




1 

1 


j IEFX5000 



IEFWCIMP 

1 

1 

IEFWC000 

j IEFALOC3 

IEFALOC2 

IEFSDOll 


1 

1 

IEFVC002 

j IEFALOC3 

IEFALOC2 

IEFSDOll 

IEFWDFAK 

1 

1 

IEFWD000 

j IEFALOC3 




1 

1 


j IEFALOC5 



IEFWD000 

1 

1 

IEFWD000 

j IEFALOC4 

IEFALOC2 

IEFSDOll 

IEFWD001 

I 

1 

IEFWD001 

| IEFALOC4 

IEFALOC2 

IEFSDOll 


Chart LSI umber 


Appears As 
Subr. Block 


Flow is 
Defined 


_x_J 
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Assembly Modules and Control Sections (Part 5 of 6) 


Assembly 
Module Name 


I EFWMAS 1 
IEFWMSKA 
IEFWSDIP 
IEFWSTRT 
IEFWSWIN 
IEFWTERM 
IEFW21SD 
IEFW22SD 
IEFW23SD 
IEFW31SD 
IEFW41SD 
1EFW42SD 
IEFXAFAK 
IEFXAMSG 
IEFXCS3S 
IEFXH000 

IEFXJFAK 


IEFXJIMP 
IEFXJMSG 
IEFXKFAK 
IEFXKIMP 

IEFXKMSG 

IEFXTFAK 

IEFXTDMY 

IEFXTMSG 

IEFXT00D 

IEFXVMSG 

IEFXVNSL 

IEFXV001 

IEFXVFAK 

IEFX1FAK 

IEFX2FAK 

IEFX3FAK 

IEFX300A 


IEFX5FAK 

IEFX5000 

IEFYNFAK 


IEFYNIMP 

IEFYNMSG 

IEFYPJB3 

IEFYPMSG 

IEFYSSMB 


Notes 


Control 
Section Name 


DEVNAMET 

DEVMASKT 

IEFWSDIP 

IEFWSTRT 

IEFSWIT 

IEFWTERM 

IEFW21SD 

IEFW22SD 

IEFW23SD 

IEFW31SD 

IEFW41SD 

IEFW42SD 

IEFXA 

IEFXAMSG 

IEFXA 

IEFXH000 

IEFXJ000 


IEFXJ000 

IEFXJMSG 

IEFXK000 

IEFXK000 

IEFXKMSG 

IEFXT000 

IEFXTDMY 

IEFXTMSG 

IEFXT000 

IEFXVMSG 

IEFXVNSL 

IEFXV001 

IEFXV001 

IEFXJ000 

IEFX5000 

IEFWC000 

IEFX3000 


IEFX5000 

IEFX5000 

IEFYN 


IEFYN 

IEFYNMSG 

IEFYP 

IEFYPMSG 

IEFYS 


Load Modules in Which 
Assembly Modules are Used 


-1 Appears As 
Subr. Block 


IEFSELCT 

IEFALOC2 

IEFIN1TL 

IEFSELCT 

IEFALOC2 

iefjterm 

IEFSELCT 

IEFSTERM 

IEFJTERM 

IEFJTERM 

IEFALOC5 

IEFSTERM 

IEFSELCT 

IEFALOC1 

IEFALOC1 

IEFALOC3 

IEFX5000 

IEFALOC2 

IEFALOC3 

IEFX5000 

IEFALOC1 

IEFALOC1 

IEFALOC4 
IEFALOC5 
IEFALOC4 
1EFALOC5 
IEFALOC4 
IEFALOC5 
IEFALOC5 
IEFALOC5 
IEFALOC4 
IEFALOC4 
IEFALOC4 
IEFALOC2 
IEFALOC4 
IEFALOC4 
IEFALOC4 
IEFALOC4 
IEFALOC2 
IEFX5000 
IEFALOC2 
IEFX5000 
IEFSELCT 
IEFALOC1 
IEFALOC4 
IEFALOC5 
IEFERROR 
IEFIDUMP 
IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFSELCT 
IEFALOC1 
IEFALOC4 
IEFALOC5 
IEFJTERM 


IEFSTERM 

IEFALOC1 

IEFINITL 

IEFSTERM 

IEFALOC1 

IEFCNTRL 

IEFSTERM 

IEFSTERM 

IEFCNTRL 

IEFJTERM 

IEFALOC2 

IEFSTERM 

IEFSTERM 

IEFALOC1 

IEFALOC1 

IEFALOC2 


IEFALOC2 
IEFALOC2 

IEFALOCl 
IEFALOC2 
IEFALOCl 
IEFALOC2 

IEFALOC2 
IEFALOC2 
IEFALOC2 
IEFALOCl 
IEFALOCl 
IEFALOCl 


IEFALOCl 

IEFALOC2 


IEFALOC2 
IEFALOCl 
IEFALOC2 
IEFERROR 
IEFIDUMP 


IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFSTERM 
IEFALOCl 
IEFALOC2 
IEFERROR 
IEFIDUMP 
IEFCNTRL 


IEFSD011 

IEFSD011 

IEFINITL 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFALERR 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 


IEFALERR 

IEFALERR 

IEFSB011 

IEFALERR 

IEFALERR 


IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 


IEFSD011 


IEFSD011 

IEFSD011 

IEFIDUMP 

IEFALERR 


IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFSD011 

IEFIDUMP 

IEFALERR 


Chart Number 


Flow is 
Defined 
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• Assembly Modules and Control Sections (Part 6 of 6) 


Assembly 
Module Name 

"T 

1 

1 

1 

| Notes 

i 

T 

1 

1 

1 

X 

Control 
Section Name 

T 

| Load Modules in Which 

j Assembly Modules are Used 

h T T 

j 18K j 44K | 100K 

XXX 

“T" 

1 

I-- 

H 

1 

- 1 - 

Chart Number 

T 

Appears As | Flow is 
Suhr. Blockj Defined 

_L 


T 


T 


T 1 

1 


T 


T 



1 


1 


| IEFERROR 



1 


1 



1 


1 


| IEFIDUMP 



1 


1 


IEFZAFAK 

1 


1 

IEFZA 

| IEFSTERM 

IEFSTERM 


1 


1 


IEFZAJB3 

1 


1 

IEFZA 

j IEFJTERM 

IEFCNTRL 

IEFSD011 

1 

14 

1 

15 

IEFZGJB1 

1 


1 

IEFZGJ 

| IEFJTERM 

IEFCNTRL 

IEF3D011 

1 

15 

1 


IEFZGMSG 

1 


1 

IEFZGMSG 

j IEFSTERM 

IEFSTERM 

IEFSD011 

1 


1 



1 


1 


| IEFJTERM 

IEFCNTRL 


1 


1 


IEFZGST1 

1 


1 

IEFZG 

| IEFSTERM 

IEFSTERM 

IEFSD011 

1 


1 


IEFZHFAK 

1 


1 

ILFZPOQM 

j IEFJTERM 

IEFCNTRL 


1 


1 


IEFZHMSG 

1 


1 

IEFZH 

j IEFSTERM 

IEFSTERM 

IEFSD011 

1 


1 



1 


1 


| IEFJTERM 

IEFCNTRL 


1 


1 


IEF04FAK 

1 


1 

IEFSDO 04 

| IEFALOC5 



1 


1 


1EF08FAK 

1 


1 

IEFSD008 

| IEFJTERM 

IEFSTERM 


1 


1 



1 


1 


j IEFSTERM 



1 


1 


IEF09FAK 

1 


1 

IEFSD009 

| IEFSTERM 

IEFCNTRL 


1 


1 



1 


1 


j IEFINTFC 



1 


1 


IEF23FAK 

1 


1 

IEFW23SD 

j IEFINTFC 



1 


1 


IEF7KGXX 

1 


1 

IEFKG 

j IEFINTFC 

IEFCNTRL 

IEFSD011 

1 


1 


IEF7KPXX 

1 


1 

IEFKP 

j IEFCOMMD 

IEFCOMMD 

IEFSD011 

1 


1 


IEF7K1XX 

1 


1 

IEFK1 

| IEFINITL 

IEFINITL 

IEFINITL 

1 


1 


IEF7K2XX 

1 


1 

IEFK2 

| IEFINITL 

IEFINITL 

IEFINITL 

1 


1 


IEF7K3XX 

1 


1 

IEFK3 

j IEFINITL 

IEFINITL 

IEFINITL 

1 


1 


IGC0103D 

1 

*** 

1 

IGC0103D 

j IGC0103D 

IGC0103D 

IGC0103D 

1 


1 


IGC0203D 

1 

*** 

1 

IGC0203D 

IGC0203D 

IGC0203D 

IGC0203D 

1 


1 



-X. 


X. 


X I J 


-X- 


-X- 



Notes : *Assembly modules in SYS1.NUCLEUS data set. 

♦♦Modules are assembled during system generation. 

♦♦♦Assembly modules in SYS1.SVCLIB data set. 

♦♦♦♦IEFACTFK may replace both IEFACTLK and IEFACTRT during system generation. 


I 

I 


1 


/ 
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CONTROL SECTIONS AND ASSEMBLY MODULES 

The following list provides a cross-reference between job management control section 
(CSECT) names, which appear in alphameric order, and the corresponding assembly module 
names. Control section names are also listed in the preceding assembly module to load 
module cross reference table. 


CSECT NAME 

ASSEMBLY MODULE NAME 

CSCECT NAME 

ASSEMBLY MODULE NAME 

DEV MAS KT 

IEFWMSKA 

IEFSD031 

IEFSD031 

DEVNAMET 

IEFWMAS1 

IEFSDO34 

IEFSD034 

IEEBA1 

IEECIR01 

IEFSDO35 

IEFSD035 

IEELB1 

IEEMCR01 

IEF3D036 

IEFSD036 

IEEBBl 

IEEMCRFK 

IEFSD059 

IEFSD059 

IEEBC1PE 

IEEBC1PE 

IEFSDO 88 

IEFSD083 

IEEBH1 

IEEBH1PE 

IEFSDO89 

IEFSD08 9 

IEEGESTO 

IEEGES01 

IEFSD090 

IEFSD090 

IEEGK1GM 

IEEGK1GM 

IEFSD094 

IEFSD094 

IEEICCAN 

IEEILCDM 

IEFSD095 

IEF3D095 

IEEICCAN 

IEEILC01 

IEFSEPAR 

IEFSEPAR 

IEEICN01 

IEECNDUM 

IEFSGOPT 

IEFSGOPT 

IEEICN01 

IEEICN01 

IEFS15XL 

IEFV15XL 

IEEICRDR 

IEEREADR 

IEFVDA 

IEFDAFAK 

IEEICWTR 

IEEWRITR 

IEFVDA 

IEFVDA 

IEEIC1PE 

IEESTART 

IEFVDBSD 

IEFVDDUM 

IEEIC2NQ 

IEEIC2NQ 

IEFVEA 

IEFEAFAK 

IEEIC3JF 

IEEIC3JF 

IEFVEA 

IEFVEA 

IEEMCREP 

IEEMCREP 

IEFVFA 

IEFVFA 

IEEMSLT 

IEERSC01 

IEFVGI 

IEFVGI 

IEEMSLT 

IEERSR01 

IEFVGK 

IEFVGK 

IEEQOTOO 

IEEQOTOO 

IEFVGM 

IEFVGMSS 

IEEVSMSG 

IEEVSMDM 

IEFVGM1 

IEFVGM1 

IEFACTLK 

IEFACTFK 

IEFVGM10 

IEFVGM10 

IEFACTLK 

IEFACTLK 

IEFVGM11 

IEFVGM11 

IEFACTRT 

IEFACTRT 

IEFVGM12 

IEFVGM12 

IEFBR14 

IEFBR14 

IEFVGM13 

IEFVGM13 

IEFDNSFT 

IEFDNSFT 

IEFVGM14 

IEFVGM14 

IEFDPOST 

IEFDPOST 

IEFVGM15 

IEFVGM15 

IEFIDMPM 

IEFIDMPM 

IEFVGM16 

IEFVGM16 

IEFIDUMP 

IEFIDFAK 

IEFVGM17 

IEFVGM17 

IEFIDUMP 

IEFIDUMP 

IEFVGM18 

IEFVGM18 

IEFINTQS 

IEFINTQA 

IEFVGM2 

IEFVGM2 

IEFKG 

IEFKGDUM 

IEFVGM3 

IEFVGM3 

IEFKG 

IEF7KGXX 

IEFVGM4 

IEFVGM4 

IEFKP 

IEF7KPXX 

IEFVGM5 

IEFVGM5 

IEFK1 

IEF7K1XX 

IEFVGM6 

IEFVGM6 

IEFK1MSG 

IEFK1MSG 

IEFVGM7 

IEFVGM7 

IEFK2 

IEF7K2XX 

IEFVGM70 

IEFVGM70 

IEFK3 

IEF7K3XX 

IEFVGM78 

IEFVGM7 8 

IEFPRES 

IEFPRES 

IEFVGM8 

IEFVGM8 

IEFPRES 

IEFPRFAK 

IEFVGM9 

IEFVGM9 

IEFQMSSS 

IEFQMSSS 

IEFVGS 

IEFVGS 

IEFSD001 

IEFSD001 

IEFVGT 

IEFVGT 

IEFSD002 

IEFSD002 

IEFVHA 

IEFHAFAK 

IEFSD003 

IEFSD003 

IEFVHA 

IEFVHA 

IEFSDO 04 

IEFSD004 

IEFVHAA 

IEFHAAFK 

IEFSD004 

IEF04FAK 

IEFVHAA 

IEFVHAA 

IEFSDO06 

IEFSD006 

IEFVHB 

IEFVHB 

IEFSDO07 

IEFSDO07 

IEFVHC 

IEFVHC 

IEFSDO08 

IEFSDO08 

IEFVHCB 

IEFHCBFK 

IEFSDO08 

IEF08FAK 

IEFVHCB 

IEFVHCB 

IEFSD009 

IEFSD009 

IEFVHE 

IEFVHE 

IEFSDO09 

IEF09FAK 

IEFVHEB 

IEFVHEB 

IEFSDO10 

IEFSD010 

IEFVHEC 

IEFVHEC 

IEFSDO11 

IEFSD011 

IEFVHF 

IEFHFFAK 

IEFSDO12 

IEFSD012 

IEFVHF 

IEFVHF 

IEFSD013 

IEFSD013 

IEFVHG 

IEFVHGSS 

IEFSDO17 

IEFSDO17 

IEFVHH 

IEFVHH 
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CSCECT NAME 

ASSEMBLY MODULE NAME 

CSCECT NAME 

ASSEMBLY MODULE NAME 

IEFVHL 

IEFVHL 

IEFW42SD 

IEFW42SD 

IEFVHM 

IEFriMFAK 

IEFXAMSG 

IEFXAMSG 

IEFVHM 

IEF7KPXX 

IEFXA 

IEFXAFAK 

IEFVHN 

IEFVHN 

IEFXA 

IEFXCSSS 

IEFVHQ 

IEFVHQ 

IEFXH000 

IEFXH000 

IEFVHR 

IEFVHRSS 

IEFXJMSG 

IEFXJMSG 

IEFVH1 

IEFVH1 

IEFXJ000 

IEFXJFAK 

IEFVH2 

IEFVH2 

IEFXJ000 

IEFXJIMP 

IEFVJA 

IEFVJA 

IEFXJ000 

IEFX1FAK 

IEFVJMSG 

IEFVJMSG 

IEFXKMSG 

IEFXKMSG 

IEFVJ 

IEFVJIMP 

IEFXKOOO 

IEFXKIMP 

IEFVKMSG 

IEFVKMSG 

IEFXTDMY 

IEFXTDMY 

IEFVK 

IEFVKIMP 

IEFXTMSG 

IEFXTMSG 

IEFVM1 

IEFVMLS1 

IEFXT000 

IEFXT00D 

IEFVM2 

IEFVM2LS 

IEFXT000 

IEFXTFAK 

IEFVM3 

IEFVM3LS 

IEFXVMSG 

IEFXVMSG 

IEFVM4 

IEFVM4LS 

IEFXVNSL 

IEFXVNSL 

IEFVM5 

IEFVM5LS 

IEFXV001 

IEFXVFAK 

IEFVM6 

IEFVMLK5 

IEFXV001 

IEFXV001 

IEFVM6 

IEFVMLS6 

IEFX3000 

IEFX300A 

IEFVM7 6 

IEFVM76 

IEFX5000 

IEFX2FAK 

IEFVM7 

IEFVMLS7 

IEFX5000 

IEFX5000 

IEFWAD 

IEFWAD 

IEFYN 

IEFYNIMP 

IEFWA000 

IEFWAFAK 

IEFYN 

IEFYNFAK 

IEFWA7 

IEFWA000 

IEFYNMSG 

IEFYNMSG 

IEFWC000 

IEFWCFAK 

IEFYPMSG 

IEFYPMSG 

IEFWC000 

IEFWCIMP 

IEFYP 

IEFYPJB3 

IEFWC002 

IEFWCIMP 

IEFYS 

IEFYSSMB 

! IEFWD000 

IEFWDFAK 

IEFZA 

IEFZAFAK 

IEFWD000 

IEFWD000 

IEFZA 

IEFZAJB3 

IEFWDO 01 

IEFWDO01 

IEFZGMSG 

IEFZGMSG 

IEFWSDIP 

IEFWSDIP 

IEFZG 

IEFZGJBl 

IEFWSTRT 

IEFWSTRT 

IEFZG 

IEFZGST1 

IEFWSWIT 

IEFWSWIN 

IEFZH 

IEFZHMSG 

i IEFWTERM 

IEFWTERM 

IEFZPOQM 

IEFZHFAK 

! IEFW21SD 

IEFW21SD 

IGC0103D 

IGC0103D 

IEFW22SD 

IEFW22SD 

IGC0203D 

IGC0203D 

! IEFW23SD 

IEFW23SD 

IGC03D 

IEEMXC01 

IEFW23SD 

IEF23FAK 

IGC03E 

IEEWTC01 

IEFW31SD 

IEFW31SD 

SPRINTER 

IEFPRTXX 

IEFW41SD 

IEFW41SD 
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CHARTS 


Chart 01. 


Job Management 


******B2*********** 


♦*****B3*********** 


* * 
CONSOLE DEVICE 
* * 


* SYSTEM * 

INPUT DEVICE 
* * 


************* 


X 

*****C2********** 
* 02A1* 


************* 

**** 

* * 

* C3 *.X« 

* * 

**** . 

X 

♦****C3********** 
* * 


* * 

* COMMUNICATION * 

♦ TASK * 

***************** 


* READER/ * 

* INTERPRETER * 

* * 
***************** 


X 

***** D 3********** 

* 12A3* 
*-*-*_*-*-*-*-*-* 

* INITATOR/ *, 

* TERMINATOR * 

* * 
***************** 


****** 04 *********** 

♦ SYSTEM * 

,X OUTPUT DEVICE 
* * 

************* 


»****E3********** 


***************** 


******E4*********** 

* JOB * 

•X STEP OUTPUT 
* DEVICE * 

************* 


X 

**** 

♦ * 

* C3 * 

* * 
**** 
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Chart 02. Communication Task Control Flow 


********* 

* * 

* ENTRY * 

* * 
*************** 


****A3********* 

* * 

* ENTRY * 

* * 
*************** 


****A4********* 

* * 

* ENTRY * 

* * 
*************** 


****A5********* 

* * 

* ENTRY * 

* * 
*************** 



FROM SUPERVISOR 
AFTER IPL 


FROM 

SUPERVISOR 


FROM 

SUPERVISOR 


FROM 

SUPERVISOR 


X 

**«**B1********** 
*IEECVCTI 03A2* 
*_*_*_*_*_*_*_*_* 

* COMMUNICATION * 

* TASK * 
♦INITIALIZATION * 
***************** 


♦***B2********* 

* * 

* ENTRY *. 

* * 
*************** 


X 

♦****B3********** 
♦IEEBB1 * 

*-*-*—*-*—*-*—*—* 
X* MASTER * 

♦COMMAND ROUTINE* 
* (SEE NOTE) * 
***************** 


X 

*****B4********** 

* 16C03D 05A1* 

*—*—*—*—*—*—#—*—* 

* COMMAND * 

* PROCESSOR * 

* * 
***************** 


X 

*****B5********** 
*IGCO11 3D 06A1* 
*-*-*—*-*—*-*—*-* 

* WRITE-TO- * 

* OPERATOR * 

* ROUTINE * 

***************** 


FROM 

READER/INTERPRETER 


X 

****CI ********* 

* * 

* EXIT * 

* * 
*************** 


X 

****C3********* 

* * 

* EXIT * 

* * 
*************** 


X 

****C4*+******* 

* * 

* EXIT * 

* * 
*************** 


X 

****C5******** * 

* 

* EXIT 

* 

*************** 


* 

* 

* 


TO COMMUNICATIONS 
TASK WAIT ROUTINE 


TO SUPERVISOR OR TO SUPERVISOR TO SUPERVISOR 

READER/INTERPRETER 


****DI********* 

* * 

* ENTRY * 

* * 
*************** 


NOTE THE MASTER COMMAND ROUTINE 
IS UNCHANGED FROM THAT OF THE 
SEQUENTIAL SCHEDULING SYSTEM. 

FOR FLOWCHART SEE JOB MANAGE¬ 
MENT PLM• FORM Z28-6613 


FROM INPUT/OUTPUT 
SUPERVISOR 


X 

****♦£1********** 
*IEEBA1 04A1* 

*-*_*-*_*_*-*-*-!.* 

* CONSOLE * 

* INTERRUPT * 

* ROUTINE * 

***************** 


****E4 ********* 

* * 

* ENTRY * 

* * 
*************** 


FROM COMMUNICATIONS TASK 
INITIALIZATION AFTER IPL 
OR FROM SUPERVISOR 


X 

****F1********* 


* * 

* EXIT * 

* * 


*************** 


X 

*****F4********** 
*IEECVCTW 07A2* 
*-*-*-*—*-*-*_*_* 
♦COMMUNICATIONS * 

* TASK WAIT * 

* ROUTINE * 

******************* 


♦ ***F 5* ■*•**♦**-** 

* * 

X* EXIT * 

* * 

*************** 




x 


TO 

SUPERVISOR 


TO 

SUPERVISOR 


****G1********* 

* ENTRY * 

* * 
*************** 


*****G4********** 
♦IEECVCTR 08A3* 
*-*—*—*-*-*-*-*-* 
♦ROUTER ROUTINE *, 


***************** 


♦****G5********** 
♦IEECVCTX 09A3* 
*—#—*—*—*—*—*—*—* 
X* EXTERNAL * 

* INTERRUPT * 

* PROCESSOR * 

***************** 

• X 


FROM 

SUPERVISOR 


X 

*****H4********** 

*IEECVPM 10A2* 

*-*-*-*_*-*-*-*_* 
X* *x 

* PROCESSOR * 

* ROUTINE * 

***************** 


X 

♦****H1********** 
♦IEEBCIPE 04A3* 
*-*-*-*-*-*-*-*-* 

* EXTERNAL * 

* INTERRUPT * 

* ROUTINE * 
***************** 


♦****H3********** 

* IGC03D 05A1 * 

*-*-*-*-*-*-*-*-* 

* COMMAND *X 

* PROCESSOR * 

* * 
***************** 


X 

****J1********* 


* * 

* EXIT * 

* * 


*************** 


X 

*****J4********** 

* IEECVOC 11A3* 

*-*-*-*-*-*-*-*-* 

* * 

* OPEN/CLOSE * 

* ROUTINE * 
***************** 


TO 

SUPERVISOR 






























Chart 03. Communication Task Initialization Routine 


IEECVCTI 

♦***A2********* 

* * 

* ENTER * 

* * 
*************** 


X 

*****62********** 

* PLACE * 

♦POINTER TO UCM * 

* IN * 

* COMMUNICATION * 

* VECTOR TABLE * 
***************** 


X 

*****C2+********* 
*IEEVRFRX * 

*-*-*-*-*-*-*-*-* 

* CONV OEV NMS * 
*IN UCM ENTRIES * 

* TO UCB ADDR * 
***************** 


THE UNIT 
CONTROL MODULE 
(UCM) CONTAINS 
DATA NECESSARY 
TO COMMUNICATION 
TASK OPERATION 


♦****C3********** 

* MARK UCB AS * 

* PRIMARY OR * 
X* ALTERNATE * 

* ACCORDING TO * 

* UCM FLAG * 
***************** 


X 

«****D2********** 

* BUILD * 

* EVENT * 

♦INDICATION LIST* 

* (EIL) * 

* * 
***************** 


X 

***«E2********* 

* * 

* RETURN * 

* * 
*************** 


THE EIL IS 
PART OF THE 
UCM AND CONTAINS 
POINTERS TO 
ECB'S + UCB'S. 
THE ECB POINTERS 
FORM THE LIST 
WAITED ON BY 
IEECVCTW 


Charts 
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Chart 04. Console and External Interrupt Routines 


CONSOLE 

INTERRUPT 

ROUTINE 

IEEBA1 

****A1********* 

* * 
* ENTRY * 

*************** 


EXTERNAL 

INTERRUPT 

ROUTINE 

IEEBC1PE 

****A3********* 

* * 

* ENTRY * 

* * 
*************** 



X 

**BI ******* 

* * 

* POST * 

* COMMUNICATION * 

* TASK * 

# * 

*********** 


X 

*****C1********** 
* * 

* FLAG DEVICE * 

* ENTRY IN UNIT * 
♦CONTROL MODULE * 

* * 
***************** 


X 

**B3******* 

♦ * 

* POST * 

♦ COMMUNICATION * 

♦ TASK * 

♦ * 

*********** 


X 

****C3********* 

* * 

* EXIT * 

* * 
*************** 


X 

****D1********* 

* * 

* EXIT * 

* * 
*************** 
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Chart 05. Master Command EXCP Routine 


IGC03D 

********* 

* * 

* ENTRY * 

* * 
*************** 


REQ COMMAND 


*****B2******* 

* * 

* TURN ON * 

X*COMMAND PENDING* 

* SWITCH * 

* * 
************** 


**** 

* * 

X* FI * 
* * 


**** 


X 

.*. 

Cl *. 

.* *. 

.* *. YES 

*. SET COMMAND .*... 

*. .* 

*. .* 

*. .* 

* NO 


X 

.*. 

D1 *. 

. * *. 

.* *. YES 

*.START COMMAND.*..., 
*• • * 

*. .* 

*. •* 

* NO 



.* *. 

.* START *. NO 
X*. (BLANK) .*... 
*. COMMAND .* 

*• .* 

*. .* 

* YES 


X. 


X 

**«**-E x ********** 

* XCTL TO * 

* COMMAND * 

* PROCESSING * 

* ROUTINE * 

* (IGC0113D) * 

***************** 

**** . 

* ♦ • 

* FI *.X. 

* * . 

**** 

X 

********* 

* * 

* EXIT * 

* * 
*************** 


X 

»****E2******* 

* * 

* TURN OFF * 
♦COMMAND PENDING* 

* SWITCH * 

* * 
************** 


X 

. * . 

E3 *. 

.* *. **** 
.* IS MASTER *. NO * * 

X*COMMAND RTN IN.*....X* FI * 
*. STORAGE .* * * 

*. .* **** 
*• .* 

* YES 


X 

**F3******* 

* * 

* POST * 

* MASTER *. 

♦SCHEDULER ECB* 

* * 

*********** 


**** 

* * 

.X* FI * 
* * 

**** 


TO SUPERVISOR 


Charts 
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Chart 06. Write-To-Operator Routine 


IGC0003E 

«***A1 ********* 

* * 

* ENTRY * 

* * 
*************** 



FROM 

SUPERVISOR 


X 

*. .*. 


B1 *. 

.* *. 


*. WTOR 

*. .* 
*. .* 

*• .* 

* NO 


B2 *. *****83********** 

.* *, *ENQ * 

YES .* REPLY *. YES *-*-*-wAIT*-*-*-* 

*..X*. QUEUE LIMIT .*.......«X* UNTIL REPLY * 

*. REACHED .* * QUEUE ELEMENT * 

*. .* * AVAILABLE * 

*. .* ***************** 

* NO 


,X 


X 

***** C2********** 

* GET, * 

* SETUP, + LINK * 
*IN REPLY QUEUE * 
♦ELEMENT ASSIGN * 

* REPLY ID * 
***************** 


X 


D2 *. 

.* *. 

NO .* WAS *. 

X...«*.ENQ REQUIRED •* 

*. .* 

*, ,* 

*, .* 

* YES 


X 

*****E2********** 
*DEQ * 

*_*_*_*_*_*_*_*_* 
X...* CANCEL * 

* PREVIOUS ENQ * 

* REQUEST * 
***************** 


X 

• *. 

FI *. 

. * *• 

.* WTO *. YES 
*. QUEUE LIMIT .*..., 
*. REACHED .* 

*. •* 

*• •* 

* NO 


*****F2********** 
*ENQ * 

*-*-*-*-*-*-*-*-* 
,X* WAIT UNTIL * 

* QUEUE ELEMENT * 

* AVAILABLE * 
***************** 


,X 



X 

*****G1********** 
* * 

* GET, SETUP, + * 

* LINK IN WTO * 

* QUEUE ELEMENT * 

* * 
***************** 


X 

• *• 

HI *. 

• * *. 

.* WAS *. YES 
*.ENQ REQUIRED .*••• 
*. .* 

*• .* 

*• •* 

* NO 


♦****H2********** 
*DEQ * 

*_*_*_*_*_*_*_*_* 
,X* CANCEL * 

* PREVIOUS ENQ * 

* REQUEST * 
***************** 


*****J2********** 
* * 

• YES * MOVE * 

..X* REPLY ID INTO * 

* MESSAGE * 

* * 
***************** 


X 

****** 1 ********** 
* * 

* MOVE WTO MSG * 

* INTO WTO QUEUE *, 

* ELEMENT * 

* * 
***************** 


**K2******* 

* POST * 

* WTO/WTOR * 

,X* REQUEST FOR * 
♦COMMUNICATION* 

* TASK * 

*********** 


****K3********* 

* * 

X* RETURN * 

* * 

*************** 
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Chart 07. Communications Task Wait Routine 


IEECVCTW* 

****A2********* 

* * 

* ENTER * 

* * 
*************** 


FROM 

SUPERVISOR 


X 

***** 82 ********** 
*I EECVCTI 03A2* 

*-*-*-*-*-*-*-*-* 

* LINK * 

*TO INIT. COMM. * 

* TASK * 

***************** 


X 

**C2******* 

* * 

* WAIT FOR * 

..X* EVENT * 

* COMPLETION * 

* * 

*********** 


X 

♦+D2******* 

* * 

* SVC72 * 

...♦PROCESS POSTED * 

♦ EVENT * 

* * 

*********** 


1. EXTERNAL 

INTERRUPT 

2. ATTENTION 

INTERRUPT 

3. WTO-WTOR 

REQUEST 

4. WTL REQUEST 

(NOT SUPPORTED) 

5. IO COMPLETION 


♦ I EECVCTW NEVER TERMINATES 


Charts 






Chart 08. Communications Task Router Routine 


IEECVCTR 


♦***A3********* 

* * 

* ENTRY * 

* * 
*************** 



• FROM 

. SUPERVISOR 
X 

• *. 

B3 *. 

.* *• ****B4********* 

.* *. YES * XCTL * 

♦•EXTERNAL ECB ... TO IEECVCTX * 

*. POSTED •* * * 

*. .* *************** 
*. •* 

* NO 


C3 *. 

.♦ANY I/O*. 
.♦COMPLETION *. YES 
*. ECB POSTED •*... 
*. .* 

*. .* 

*. .* 

* NO 


*****C4********** 
* * 

*SET UP POINTERS* 
iX* FOR PROCESSOR * 

* MODULE IN XSA * 

* * 
***************** 

X 


****C5********* 
♦XCTL TO IEECVPM* 
X* PROCESSOR * 

* MODULE * 

*************** 


X 

• *. 

D3 *. 

.* *. 

.* *. YES 

♦ .ATTENTION ECB.*.. 

*. POSTED .* 



* NO 


X 

• *• 

E3 *. 

• * *• 

.* WTO *. YES 
*. ECB POSTED .*..., 
*. .* 

*. .* 

*. .* 

* NO 


♦****E4********** 

* LOCATE * 

* CURRENTLY * 
X* ACTIVE WTO/R * 

* DEVICE * 

* * 
****************** 


X 

.*. 

*****F2********** F3 *• 

* * .* *. 

* SET * NO .* WTL * 

♦RETURN CODE OF ... ECB POSTED 

* X'OO* * *. .* 


*. .* 


***************** 


*. .* 


*****F4*+******** 
* * 

YES * SET * 

*........X*RETURN CODE OF * 

* X•04• * 

* * 
***************** 



****G2********* 

* RETURN * 

* TO IEECVCTW * 

* * 
*************** 


****G4********* 

* RETURN * 

* TO IEECVCTW * 

* * 
*************** 
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Chart 09. External Interrupt Processor Routine 


IEECVCTX 

****A3********* 

* * 

* ENTRY * 

* * 
*************** 


X 

*****B3********** 
* * 

* * 

* INITIALIZE * 

* POINTERS * 

* * 
***************** 


*****C2*+******** 

* * 

* TURN * 

* ON CLOSE FLAG *X, 

* * 

* * 

***************** 


• X.. 

X 

C3 *. 

. * *. 

YES .♦ DEVICE ♦ . 
..«*. ACTIVE AND .* 
♦ . OPEN .♦ 

♦ . .* 

*. • ♦ 

* NO 


X 

***** 02 ********** 
* * 

* * 

♦ADJUST UCM AND * 

* UCB * 

* * 
***************** 


X 

D3 ♦ . 

.* ♦ . 

. ♦ ♦ .NO 

♦ . LAST DEVICE 
** .* 

♦ • • ♦ 

♦ . .* 

* YES 


X 

****E2********* 

* XCTL TO * 
♦PROCESS MOD. TO* 

* CLOSE ♦ 

*************** 


X 

****#E3********** 
* * 
* * 

* REINITIALIZE * 

* UCM POINTERS * 

* * 
***************** 


X 

+****P3********** 

♦ FLIP * 

♦ DEVICE * 

♦ACTIVE/INACTIVE+ 

♦ FLAG ♦ 

♦ * 
***************** 


X 

.♦. 

G3 ♦• 

• ♦ ♦. 

. * * . NO 

♦. LAST DEVICE .♦... 
♦ . .♦ 

♦ . . ♦ 

♦ • .♦ 

* YES 


♦♦♦♦♦H3++♦♦♦♦♦♦♦♦ 


***************** 


X 

♦♦♦♦J3********* 

* * 

♦ RETURN ♦ 

* * 
*************** 


Charts 
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Chart 10. Communications Task Processor Routine 


IEECVPM 

****A2********* 

* * 

* ENTRY * 

* * 
*************** 


if" 

L 


***** 81 ********** 
♦IEECVOC 11A3* 

*-*-*-*-*-*_*_*_ 


♦ OPEN/CLOSE 

* ROUTINE * 

***************** 


*X..CLOSE REQUEST.* 


BUSY FLAG 


****D1********* 

* * 

* RETURN * 

* * 
*************** 


♦****E2 ********** 
* * 

* CLEAR * 

* I/O COMPLETE * 

* ECB * 

* * 
***************** 


*****F1********** 

*IEEBB1 * 

*—*—*—*—*—*—*—*—* 

* COMMAND *X 

♦PROCESSOR (SVC ♦ 

♦ 34) ♦ 

***************** 


*****$\********** 


***************** 


*****G2********** 


***************** 


*****84********** 


***************** 


*****C4♦♦♦♦♦♦♦♦♦♦ 
* * 

♦ INITIALIZE ♦ 

♦ INPUT CHANNEL ♦ 

♦ PROGRAM ♦ 

♦ ♦ 
***************** 


*****85********♦♦ 


***************** 


*****C5****♦♦♦*♦♦ 
* ♦ 

♦ INITIALIZE ♦ 

♦OUTPUT CHANNEL * 

♦ PROGRAM ♦ 

♦ ♦ 
***************** 


***** 04 ********** 
* * 

* SET BUSY FLAG * 

* * 

* * 

***************** 


**E4******* 

* * 

EXCP 

* * 

*********** 


****F4********* 


*************** 


L J 

''irJP 


***+*Hl********** 
♦IEECVOC 11A3* 

*-*-*-*-*-*-*u-*_* 

* *X 

* OPEN/CLOSE * 

* ROUTINE * 
***************** 


.X. 

X 

.*. 

J2 *. 

.* *• **** 

.* *. YES * * 

*. ATTENTION .*....X* B4 * 
*. REQUEST .* * * 

*. .* **** 

*. .* 

* NO 


X 

**** 

* * 

* B5 * 

* * 
**** 
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Chart 11. OPEN/CLOSE Routine 


IEECVOC 

*#**A3********* 

* * 

* ENTRY * 

* * 
*************** 


X 

.*. 

B3 *. 

4 * *• 

•* *. CLOSE 

♦.OPEN OR CLOSE.*...... 

* . . ♦ 

*. • * 

*. .* 

* OPEN 


**B4******* 

* * 


X* CLOSE DCB * 
* * 

* * 
*********** 


X 

*****C3********** 
* * 

* INITIALIZE * 

*DCB * UCM, ETC. * 

* FOR OPEN * 

* * 
***************** 


X 

♦****C4********** 
* * 

* * 

* ADJUST UCM * 

* * 

* * 

***************** 


X 

**D3** ***** 

* * 

* * 

* OPENJ * 

* * 

* * 

*********** 


X 

****04********* 

* XCTL TO * 

* EXTERNAL * 

* PROCESSOR * 

*************** 


X 

*****E3«********* 
* * 

* ADJUST UCM * 
*T0 REFLECT OPEN* 

* STATUS * 

***************** 


X 

****F3********* 

* XCTL * 

* TO PROCESS * 

* MODULE * 

*************** 


Charts 
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Chart 12. Initiator/Terminator Control Flow 


****A3********* 

* * 

* ENTRY * 

* * 
*************** 

I FROM READER/ 
•INTERPRETER 


o 


*****B3********** 


* * 

* INITIATOR * 

* CONTROL * 

***************** 


X 

*+***C3********** 
* * 
*-*-*-*-*-*-*-*-* 
* * 
♦ALLOCATION AND ♦ 
♦ SETUP ♦ 
***************** 


X 

♦****D3********** 
* * 
*—*—*—*—*—*—*—*—* 
* * 
♦STEP INITIATIONS 
♦ ♦ 
***************** 


X 

♦♦♦♦E3SSSS++SS+ 

* * 

* EXIT * 

* * 
*************** 

TO PROCESSING 
PROGRAM 


♦♦♦♦F3♦**♦♦♦♦♦* 

♦ * 

♦ ENTRY ♦ 

* * 
*************** 




FROM 

SUPERVISOR 

OR AN INIT/TERM 

ROUTINE 


X 

*****G3*«******** 

♦ 13A1 * 
*-*_*-*_*-*_*-*-* 

* ♦ 

♦ TERMINATOR ♦ 

* * 
***************** 


X 

****H3********* 


* * 

♦ EXIT ♦ 

* * 
*************** 


TO READER/ 
INTERPRETER OR 
INITIATOR CONTROL 











Chart 13. Pre-Termination Routine (ISFSD034) 


****A1 ********* 

♦ * 

* ENTRY * 

# * 
*************** 


PROBLEM PROGRAM 
PROCESSING. JOB 
TO TERMINATE IN 


HAS COMPLETED 
IS ATTEMPTING 
THIS PARTITION 


FROM ABEND WHEN PROB PROG 
ISSUES HIGHEST-LEVEL RETURN 


X 

*«***B1********** 

* ACCESS * 

* PTN'S PRSCB * 
♦THROUGH PNTRIN * 

* CURRENT TCB'S * 

* BBOX * 

***************** 


X 

.♦. 

Cl *. 

.* POST *. 
.♦FLAG ON (ISS. NO 
♦.SCHDLR ASGND .♦.. 
♦.TO PTN B).♦ 

♦ . .♦ 

*. .* 

♦ YES 


♦♦♦♦♦C2SS♦♦♦♦♦♦♦♦ 
* * 

♦ ISSUE MSG— ♦ 

,X+ PARTITION ♦ 

♦ WAITING TO ♦ 

♦ TERMINATE ♦ 

***************** 


X 

♦♦♦♦Dl♦♦♦♦♦♦♦♦♦ 

* WAIT ON PTN'S * 
♦SCHDLR—CONT ROL SX 

♦ ECB ♦ 

*************** 


X 

♦♦♦♦♦D2+S♦♦♦♦♦♦♦♦ 
* * 

* ISSUE WAIT * 

♦ TO DECREMENT ♦ 

♦ WAIT COUNT ♦ 

* * 
***************** 


SATISFIED BY POST IN 
IEFSD031 CHART 17 


X 

*****E 1♦♦♦♦♦♦* 

♦ SET ♦ 

♦ FIRST-TIME ♦ 
*WAITR SWITCH ON* 

♦ IF COMPLETIONS 

♦ CODE IS 4 ♦ 
************** 


♦♦♦♦FI♦♦♦♦♦♦♦♦♦ 

♦ ♦ 

♦ EXIT ♦ 

* * 
*************** 


TO TERMINATOR'S STEP TERM¬ 
INATION ROUTINE (IEFSDOll) 


Charts 












Chart 14. Termination Control Flow 


****A3********* 

* * 

* ENTRY * 

* * 
*************** 

Ifrom supervisor or 

.AN INIT/TERM ROUTINE 



X 

*****B3********** 

*IEFSDO11 * 

*—*—*—*—*—*—*—*—*NO MORE STEPS 

* STEP .. 

* TERMINATION *TO BE RUN 

* ROUTINE * 

***************** 


X 

****C3********* 

* * 

* EXIT * 

* * 
*************** 


TO READER/ 
INTERPRETER OR 
SYSTEM CONTROL 
ROUTINE 


****D3********* 

* * 

* ENTRY * 

* * 
*************** 


FROM READER/ 
INTERPRETER 


X 

♦****E3********** 
*IEFZA 15AI * 

*—*—*—*—*—*—*—*—* 

* JOB *X 

* TERMINATION * 

* ROUTINE * 
***************** 


X 

****F3********* 

* * 

* EXIT * 

* * 
*************** 




TO READER/ 
INTERPRETER 
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Chart 15. Job Termination Routine 



IEFZA 

****A1********* 

* * 

* ENTRY * 

* * 
*************** 


FROM READER/INTERPRETER 
CONTROL ROUTINE OR 
STEP TERMINATION ROUTINE 


**** 

* * 

* B4 * 

* * 
**** 


**B1******* 
*GET MAIN FOR* 

* REG. SAVE * 

*AREA• PDQ, AND * 

* DISP/UNALOC * 

* WORK AREA * 

*********** 


X 

• *. 

B4 *. 

.* *. **** 

.* IS DATA *. YES * * 

♦.SET RECEIVED -*....X* G4 * 
*. .* * * 
.* **** 

*. .* 

* NO 


X 

Cl* *♦. 

.* *. **** 

.* IS *. NO * * 

*. THERE A PDQ .+....X* HI * 
*. * * 
*. .* **** 
*• •* 

* YES 
**** . 


ZAA400 X 

*****04********** 
* * 

* SET UP * 

*LCT PARAMETERS * 

* * 

* * 

***************** 


* D1 *.X. 

* * • 

**** . 

ZAA300 X 

*****D1********** 
♦IEFZA * 

*_*_*_*_*_*_*_*_* 

* READ * 

* PDQ DIR BLOCK * 

* * 


X 

.*. 

D4 *. 

.* *. 

.* IS DATA *. NO 
*. SET ON D.A• .*... 

*. DEVICE .* 

*. .* 


***************** 


*. .* 

* YES 


ZAA3150 X 

****♦£1********** 
♦IEFZA * 

*-*-*-*-*-*-*-*-* 

* READ * 

♦PDQ ENTRY BLOCK* 

* * 
***************** 


X 

*****E4******* 


* * 

* TURN * 

♦ON D.A. SWITCH * 

* * 

* * 


************** 



**** 

* * 


**** X 
ZAA320 •*• 

FI *. 

.* *. **** 
.♦ LAST ♦.NO ♦ * 

*. PDQ ENTRY .*....X* B4 * 
*. BLOCK .* * * 

*• •* **** 

*• .* 

* YES 


G1 *. 

.* *. **** 
.* LAST *. NO * * 

*.PDQ DIR BLOCK.*....X* D1 * 
*• .* * * 



* YES 
**** . 

* * 

* Hi *.X. 

* * . 

**** • 

ZAA520 X 

*****H1********** 
♦IEFZG * 

*-*-*-*-*_*_*_*-* 

* JOB * 

* TERMINATE SRT * 

* CLEANUP * 

***************** 


,X 


ZAA420 X 

****+F4********** 
♦IEFZG * 

*—*-*—*-*-*—*-*-* 

* PERFORM DISP * 

* AND * 

* UNALLOCATION * 
***************** 

**** . 

* ♦ . 

* G4 *•X• 

* * • 

**** . 

ZAA330 X 

*»***G4********** 
* * 

* INCREMENT * 

* DATA SET * 

* POINTER * 

* * 
***************** 


X 

**** 

* * 

* FI * 

* * 
*#*# 


ZAA600 X 

**J1******* 

* * 

* * 

* FREEMAIN *, 
* * 

* * 

*********** 


IEFACTLK .*. 

J2 *. 

• * *. 

.♦IS THERE A *. YES 
..X*USER'S ACCOUNT.*..., 
*. ROUTINE .* 

♦ . .♦ 

*• •* 

* NO 


*****J3********** 

*1EFACTRT * 

*_•*_■*_*_*_*_*_*_* 
X* USER'S * 

* ACCOUNTING * 

* ROUTINE * 

***************** 


***** 
*16 * 
* Al* 


TO READER/INTERPRETER 
CONTROL ROUTINE AT 
IEFS0008 


X 

***** 

*16 * 

* Al* 

* * 

TO READER/INTERPRETER 
CONTROL ROUTINE AT 
IEFS0008 
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Chart 16. Shift Count Interrogator Routine (IEFSD035) 


****A1********* 

* * 

* ENTRY * 

* * 
*************** 


JOB IN PARTITION TO WHICH SCHEDULER IS 
ASSIGNED HAS COMPLETED TERMINATION. 



. FROM IEFACTLK IF NO USER'S 

. ACCOUNTING ROUTINE- 

. OTHERWISE, FROM IEFACTRT 

X 

******61 ********** 

♦ACCESS CURRENT ♦ 

♦ PRSCB THROUGH ♦ 

♦M. S. RESIDENT ♦ 

♦ CONTROL DATA ♦ 

♦ AREA * 

***************** 


X 

.♦• 

Cl ♦. 

.* IS *. 

.♦ SCHEDULER ♦. YES 
♦. ALREADY IN .*... 
♦.PARTITION.♦ 

*. 0 .♦ 

*. . * 

♦ NO 


*****C2******* 

* * 

♦ ZERO OUT ♦ 
...X* ANY REMAINING ♦ 
X * SHIFT COUNT ♦ 

• * * 

. ************** 


****C3********* 

* * 

X* EXIT * 

* * 

*************** 


TO READER/INTERPRETER 
CONTROL ROUTINE (IEFSD008) 


X 

.*. 

D1 *. 

• * *. 

.* IS *. YES 

*. SHIFT COUNT .*..., 
*. ZERO .* 

*. .* 

*. •* 

* NO 


X 

♦****E1********** 
* * 

* DECREMENT * 

♦SHIFT COUNT BY * 

* 1 * 

* * 

***************** 


X 

****F1********* 


* * 

* EXIT * 

* * 


*************** 



TO SCHEDULER UPSHIFT 
ROUTINE CHART 17 
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Chart 17. Scheduler Upshift Routine (IEFSD031) 


****A1********* 

* * 

* ENTRY * 

* * 
*************** 


PARTITION 


RELINQUISHING SCHEDULER CONTROL 
(JOB HAS TERMINATED, SHIFT COUNT 
WAS NON-ZERO) 


PARTITION A 


NEXT-HIGHER-PRIORITY PAR¬ 
TITION (RECEIVING SCHDLR CONTROL) 


FROM SHIFT COUNT 
INTERROGATOR (IEFSD035) 


X 

♦****B1********** 
♦FREEMAIN * 
*-*-*-*-*_*-*-*-* 
♦FREE CORE GOT- * 
♦TEN BY TERMINA—♦ 
♦ TION ROUTINES ♦ 
***************** 


X 

*****C1♦♦♦♦♦♦♦♦♦♦ 
♦GETMAIN ♦ 

*-*—*-*-*—*-*-*-* 

♦ GET CORE ♦ 

♦FOR USE BY THIS* 

♦ ROUTINE ♦ 

***************** 


X 

***** 01 ********** 
*IEFSD007 * 

*_*_*_*_*_*_*_*_* 
♦READ PTN A LCT * 
*SCT, + JCT FROM* 
♦Q-MGR VAR AREA ♦ 
***************** 


X 

*****E1********** 

* IEFQMSSS * 

*-*—*—*—*—*-*—*—* 

* WRITE PTN A * 

* LCT/SCT/JCT * 
♦INTO FIXED AREA* 
***************** 


X 

1 ********** 
♦FREEMAIN * 

*_*_*_*_*_*_*_*_* 

* FREE GOTTEN * 

* CORE (EXCEPT * 

* JCT) * 

***************** 


X 

♦****G1********** 

* RESET * 

♦POINTER TO PTN * 
♦WITH SCHEDULER * 

* CONTROL * 

* (S D33LNGH) * 

***************** 


X 

♦****H1********** 

* MAKE FORMER * 
*PTN B VARIABLE * 

* AREA AVAIL TO * 

* Q-MGR FOR RE- * 

* ASSIGNMENT * 
***************** 


X 

* POST * 

* SCHEDULER- * 
♦CONTROLLING ECB* 
♦FOR PARTITION A* 

* * 
***************** 


X 

****K1********* 

* WAIT ON PTN * 

* B'S SCHEDULER *, 

* CTL ECB * 
*************** 


♦***K2********* 

* * 

X* EXIT * 

* * 

*************** 


TO IEFSD030 CHART 18 WHEN 
SCHEDULER AGAIN RELEASED 
PARTITION B THROUGH WAITR 
IN PARTITION A. 
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Chart 18. Scheduler Downshift Routine (IEFSD030) 


PARTITION A — ISSUED WAITR 

PARTITION B - NEXT LOWER- 

PRIORITY PARTITION 


*****B2********** 


*****C2********** 

* ZERO * 

* OUT PTN B'S * 

* PRSCB EXCEPT * 
♦POST FLAG + ID * 

* * 
***************** 


***** 02 ********** 
*GETMAIN * 

*-*-*_*_*_*_*_*_* 

* GET 488 BYTES * 

* FOR THIS RTN * 
*(INCL. SCT/JCT)* 
***************** 


*****E2********** 
*IEFSD007 * 

*-*-*-*-*_*_*_*_* 

* READ IN LCT * 

* USED FOR * 

* PARTITION A * 
***************** 


*****F2*+******** 
♦GETMAIN * 

*-*—*-*-*-*-*_*-* 

* GET CORE FOR * 
♦LCT TO BE USED * 

* FOR PTN B * 
***************** 


♦****G2********** 
♦BUILD NEW LCT, * 

* SAVE LENGTH, * 

* SRT, + TCB * 

* PTR—, ZERO * 

* REMAINDER * 
***************** 


*****H2*+******** 
♦IEFSD007 * 

*-*-*-*-*_*_*-*_* 
♦WRITE PTN BLCT * 

* INTO Q-MGRS * 

* FIXED AREA * 
***************** 


♦****J2********** 

* IEFSD007 * 

*-*-*-*-*-*-*-*-* 
♦WRITE PTN A LCT* 

* INTO PTN A * 

* VARIABLE AREA * 
***************** 


*-**** K 2* ********* 

*IEFSD006 * 

*_*-*_*-*-*_*_*_* 

* GET *. 

*TTR FOR JCT AND* 

* SCT * 

***************** 


*****B4«********* 

* IEFQMSSS * 

*-*-*-*-*-*-*-*-* 

X* READ IN * 

♦PARTITION A SCT* 

* AND JCT * 
***************** 


TURN ON FLUSH* 
BIT IN * 

PARTITION A'S* 
JCT * 
************* 


*****04********** 
* * 

* PREPARE * 

* TO WRITE JCT * 

* AND SCT * 


* SAVE POINTERS * 
*TO Q-MGR EXT IN* 

* PTN A ' S PRSCB * 

* * 
***************** 


♦****F4********** 

*IEFQMSSS * 

*-*-*-*-*-*-*-*-* 
♦WRITE PTN B JCT* 

* AND SCT INTO * 

* FIXED AREA * 
***************** 


*****G4********** 

♦FREEMAIN * 

*-*-*-*-*-*-*-*-* 

* FREE 304 OF * 
*488 BYTES (SAVE* 

* JCT FOR R/I) * 
***************** 


**«**H4********** 

* ISSUE * 

* 'PARTITION B * 

* STARTED* * 

* MESSAGE * 
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Chart 19. Enqueue Service Routine 


IGC056 

****a1********* 

* * 

* ENTRY * 

* * 
*************** 


. FROM SVC FLIH 

X 


B1 *. 

.* *. ****B2********* 

.* *. NO * * 

♦ .VALID REQUEST.*.X* ABEND * 

*. .* * * 
*. .* *************** 
*. •* 

* YES 


X 

♦****C1********** 
♦FINDMAJ * 

*-*-*_*_*_*-*_*_* 
..X* FIND QCB * 

. +MATCHING MAJOR * 

. * NAME * 

. ***************** 

♦ • 

* * # 

*19 * 

* Bl* 

***** . 

X 

D1 *. 

.* *• 

.* MAJOR *. NO 
*. QCB FOUND .*.. 
*. .* 

*. . * 

*. .* 

* YES 


X* 


D2 *. 

.* *. 

,* EXAMINE *. 
iRET PARAMETER.* 

* • . * 

*. .* 

*. .* 

* 


*»***C3********** 

* * 

* SET * 

X* ‘AVAILABLE* *. 

* RETURN CODE * 

***************** 


USE* 

.....X 

HAVE 


***** 03 ********** 
* * 

* SET * 

X* ‘AVAILABLE* * 

RETURN CODE * 

* * 
***************** 


*****E3********** 

* GET STORAGE * 

NONE * AND CREATE * 

.....X* MAJOR QCB. *. 

♦MINOR QCB, AND * 

* QEL * 

***************** 


• X 


X 

* ****F1 ********** 

♦FINDMIN * 

*— *— *-*—*—*—*-*-* 

* FIND QCB * 
♦MATCHING MINOR * 

* NAME X * 

***************** 


X 

• *. 

G1 *. 

• * *• 

.* MINOR *. NO 
*. QCB FOUND .*.., 

*. .* 

*• .* 

*. .* 

* YES 


X 

****** 1 ********** 
*FINDQEL * 

*_*_*_*_*_*_*_*_* 

* FIND * 

* QEL MATCHING * 

* MASK * 

***************** 


.* . 

G2 *. 

• * *• 

.* EXAMINE *. 
X*•RET PARAMETER.* 
*• •* 


* . • * 


*****F3******** ** 
* * 

* SET * 

X* ‘AVAILABLE' *. 

* RETURN CODE * 

* * 
***************** 


♦****G3********** 
* * 

* SET * 

X* 'AVAILABLE' * 

* RETURN CODE * 

* * 
***************** 


*»***H3* ********* 

* GET * 

NONE * STORAGE AND * 

.....X* CREATE MINOR *. 

* GCB AND QEL * 


***************** 


X 


X 

***** 


*21 * 
* Bl* 


X 

***** 
*20 * 
* Bl* 
* * 
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Chart 20. Enqueue Service Routine (continued) 


***** 
*20 * 
* Bl* 


*****B3********** 


•* DUPLICATE *. YES 
. REQUEST BY .*.... 
*.THIS TASK.* 


.* INQUIRY *. YES 
•X*•(RET EQ HAVE,.*.... 
*. USE, OR .* 

*.TEST)•* 


**C2******* 

* * 

ABEND 

* * 

*********** 


MUST - *. 

COMPLETE 
•REQUESTED.* 


**************** 


NO ,*SUPERVISOR 
...*. ROUTINE 

♦REQUESTING. 


• *•SHARED * OR*. 
. 'EXCLUSIVE* . 
*. REQUEST .* 


*****D3********** 
* * 

* SET * 

X*'IN USE* RETURN* 

* CODE * 

* * 
***************** 


***** 04 ********** 

* SET * 

♦MUST - COMPLETE* 

* FLAG (STEP OR *. 
♦SYSTEM) IN QEL * 

* * 
***************** 


*****E2********** 
♦UPSVRB * 

*—*—■*—■*—*-*—*—*—* 

* INCREMENT * 
*SVRB WAIT COUNT* 

* * 
***************** 


*****F2********** 

* * 

* SET * 

X* 'AVAILABLE* *. 

* RETURN CODE * 

* * 
***************** 


♦****G2********** 
* * 

* SET * 

X* 'AVAILABLE' * 

* RETURN CODE * 

* * 
***************** 


•*•***•* H2** ******** 

* * 

* GET * 

X* STORAGE AND *. 

* CREATE QEL * 

* * 
***************** 




***** 
*21 * 
* Bl* 
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Chart 21. Enqueue Service Routine (continued) 


* SCAN RETURN * 

* CODES IN * 
♦PARAMETER LIST ♦ 


.* MORE ♦ . YES 
♦. ELEMENTS TO ...... 

♦. PROCESS .♦ 


♦♦♦♦♦01♦♦♦♦♦♦♦♦♦♦ 

♦ ACCESS ♦ 

♦ TOP PARAMETER ♦ 

♦ ON LIST, USE ♦ 

♦ FOR REMAINING * 

♦ TESTS ♦ 

***************** 


.♦ SVRB ♦ . N 

♦. WAIT COUNT .♦. 
*. ZERO .♦ 


♦ SAVE ♦ 

•REGISTERS IN ♦ . 

♦ TCB ♦ 

♦ * 
***************** 


♦ SET ON 'STEP ♦ 
♦MUST COMPLETE* * 

♦ FLAG IN TCB ♦ 

♦ * 
***************** 


♦SET ON 'SYSTEM ♦ 
♦MUST COMPLETE* * 
♦ FLAG IN TCB ♦ 


*****J2+**♦♦*♦*♦* 
♦SETRSMC 22B1♦ 
*-*_*_*-*-*_*_*_* 

♦ SET TCB ♦ 
*DISPATCHABI LITY* 

♦ AS REQUIRED ♦ 
***************** 


.♦ ALL ♦ 

.RETURN CODES 
*. ZERO .* 


****»C4*♦♦♦♦♦♦♦♦♦ 

♦ SET ♦ 

♦ GPR15 TO ♦ 

♦ ADDRESS OF ♦ 

♦PARAMETER LIST ♦ 


*****E3 + + ^ + 4 + ^ + 
♦ ♦ 
♦SET RESUME PSW * 
. X^ TO SMC ADDR. ♦ 
♦ NEW TO GPR15 ♦ 


****F3* * ******* 


♦ DEFER ♦ 

♦ ASYNCHRONOUS ♦. 

♦ EXITS ♦ 

♦ * 
***************** 


EXIT 

*****K3^**♦**♦♦♦♦ 
♦MCRET2 21A4♦ 

*—*—*—*—*—*—*—*—* 
..X+ CHECK ♦ 

♦AND SET RETURN ♦ 
♦ CODES ♦ 

***************** 
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Chart 22. Must Complete Routine 


IEAGSMC X 

* * 

* SET UP * 

* BASE REGISTER * 

* * 

* * 

***************** 


X 

.*« 

Cl *. 

.* *. ****C2********* 

.* STEP MUST *. YES * * 

*. COMP. ... RETURN * 

♦•REQUESTED.* * * 

*. .* *************** 

♦ . . * 


* 


SETRSMC X 

***** 01 ********** 

♦ GET FIRST ♦ 

♦ PARTITION TCB * 

♦ ADDRESS ♦ 

♦ * 
***************** 


**** . 
♦ ♦ . 

♦ El *.X. 

♦ ♦ • 

♦ *** X 


El ♦. 

• ♦ ♦. 

.♦ SET MUST ♦. NO 
♦. COMP. .♦.. 

♦•REQUESTED.* 

♦ • . ♦ 

♦ . .♦ 

♦ YES 


*****E2********** 

♦ SET ♦ 

♦ TCB ♦ 

,X* DISPATCHABLE ♦ 

♦ * 

♦ * 

***************** 


X 

*****F 1 ********** 
♦ * 

♦ SET TCB ♦ 

♦ NON- ♦, 

♦ DISPATCHABLE ♦ 

♦ * 
***************** 


X 

*****F2********** 
♦ * 

♦ GET ♦ 

,X*NEXT PARTITION ♦ 

♦ TCB ♦ 

♦ * 
***************** 


/*. 

W.> y ' 


X 

• ♦• 

G2 ♦. 

• * *• 

.♦ ♦. YES 

♦. END ...... 

♦ • • * 

♦ . .* 

*. .* 

♦ NO 


*****G3********** 
♦ * 

* GET ♦ 

X*REQUESTING TCB * 

* ADDRESS ♦ 

* * 
***************** 


X 

**** 

* * 

♦ E1 ♦ 

* * 
**** 


X 

*****H3********** 

♦SET REQUESTING * 

* TCB * 

* DISPATCHABLE * 

* * 
***************** 


X 

****J3********* 


* * 

* RETURN * 

* * 


*************** 
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Chart 23. Dequeue Service Routine 



##**Al**###-»#** 

* * 

* ENTRY * 

* * 
*************** 


FROM SVC FLIH 


X 

CHKLIST .*. 

B1 *. 

.* *. *»**B2********* 

.* ♦ . NO * * 

* .VALID REQUEST.*.X* ABEND * 

*• •* * * 

*. .* *************** 

*. .* 

* YES 

**** 

*23 * 

* Cl *.X. 

* * 

**** . 

PARMLOOP X 

*****<;i ********** 

*FINDMAJ * 

*-*-*-*-*-*-*-*-* 

* * 

* LOCATE MAJOR * 

* QCB * 

***************** 


X 


D1 *. 

. * * 
.* MAJOR 
*. QCB FOUND 


* . . ♦ 
*. .* 

* YES 


* 


NO 

*.. 


X 

*****E1********** 
♦FINDMIN * 

*_*_*_*_*_*_*_*_* 
* * 

* LOCATE MINOR * 

* QCB * 

***************** 


**** 

* * 

* F2 * 

* * 
**** 



X 

*. 


.* MINOR *. NO 
*. QCB FOUND .*.., 

*. .* 

*• • * 

*. . * 

* YES 


•X*. RET = HAVE 


* NO 


*****F3*+******** 
* * 

* * 

X*SET RETURN CODE* 
* 08 * 

* * 

***************** 


X 

*****G1********** 
* * 

* GET TOP QEL * 
*IN MINOR QCB'S * 

* QUEUE * 

* * 
***************** 


X 

****Gi2* ******** 

* * 
♦ABEND WITH CODE* 
* = 130 * 

*************** 


X 

***** 
*24 * 
* F4* 
* * 

* 


X 

. *• 

HI *. 

.* DID *. 

.* DEQ'ING *. NO 
♦.TASK ENQ THIS.*.. 
*. QEL .* 

*. .* 

*. .* 

* YES 


X 

***** 
*24 * 
* Al* 
* * 

* 


QELLIST .*. 

H2 *. 

.* IS *. 

.* QEL *. 
,..X*.EXCLUSIVE OR • 
X *. SHARED .* 

• * • . * 

. *. .* 

• * SHRD 


X 

GETNEXT .♦. 

J2 *. 

.* *. 

.* END OF *. 
*. QEL QUEUE 
♦. REACHED .* 
*. .* 

* • .* 

* NO 


DQERR2 


EXCL .* 

♦.X*. 

X * 


**** 

* * 

* H3 * 

* * 
**** 


**** 

YES * * 

*••••X* F2 * 
* * 

**** 


X 

.*. 

H3 *. 

* *• 
END OF * 
QEL QUEUE 
REACHED .* 
*. . ♦ 

*• . * 

* YES 


X 

**** 

* * 

* F2 * 

* * 
**** 


. NO 

.*. 

H4 ♦. 

.* WAS *. 

NO .* (NEXT)QEL *. 

‘.. ENQ * D BY .* 

*. DEQ*ING .* 
♦.TASK .* 

*. •* 

* YES 


X 

DQERR2A .*. 

J4 *. *****J5********** 

.♦ ♦. * * 

.* *. YES * * 

*. RET = HAVE .*.X*SET RETURN CODE* 

*. •* * 04 * 

*• .* * * 

*. ,* ***************** 

* NO 


X 

QELNEXT .*. 

K2 *. 

•* WAS *. 
NO •*(NEXT) QEL * 
...*. ENQ'D BY 

*. DEQ'ING .* 
♦.TASK .* 

*• •* 

* 



YES 

*...< 


. *• 

K3 *. 

.* IS *. 
.* QEL * 
X*.EXCLUSIVE OR 
*. SHARED .* 
*. •* 

*• • * 

* SHRD 


X 

***** 
*24 * 
* Al* 
* * 

* 


EXCL 

,*.... 


X 

**** 

* * 

* H3 * 

* * 
**** 


X 

****K4********* 

* * 
♦ABEND WITH CODE* 
* = 530 * 

*************** 


X 

***** 
*24 * 
* F 4* 
* * 
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Chart 24. 


Dequeue Service Routine 


(continued) 


***** 


*24 * 
* Al* 
* * 

* 



X 

TOPQEL .*. 


*, 


Al 


*. 

*. 

*. 


*. 

*. 


*****A2********** 
* * 


*. YES * SET RETURN * 


HAVE .*....X* CODE 00 * 

.* * (AVAILABLE) * 

.* * * 

.* ***************** 


* NO 

• X • . . 


X 

♦****B1********** 
♦DECTCB * 


*—*—*—*-*—*—*-*-* 

* DECREMENT * 
*TCB COUNT FIELD* 

* * 
***************** 


X 

*****ci********** 
* * 

* COMPLEMENT * 

* CURRENT QEL * 

* ADDRIF SHARED * 

* * 
***************** 


REMOVE X 

***** 01 ********** 
♦DQELEMENT * 


♦REMOVE ELEMENT * 

* FROM MINOR * 

* QCB'S QUEUE * ***** 

***************** *24 * 

• * E4* 

• * * 

♦ * 


X 

• *• 

El *. 

• * *. 

.* MORE *. NO 
*. QEL* S ON .*.., 
*. QUEUE .* 

*. .* 

*• .* 

* YES 


PROCMIN 

*****E2********** 
*DQMINOR * 

*_*_*_*_*_*_*_*_* 

, ..X* REMOVE MINOR *. 

* QCB FROM * 

* MAJOR'S QUEUE * 
***************** 


X 

• *« 

FI *. 

.* *. 

.* IS NEXT *• EXCL 
*.QEL EXCLUSIVE.*.... 
*.OR SHARED.* 

*• •* 

*. .* 

* SHRD 


PLUSQEL 

*****F2********** 
♦DECSVRB 25A1* 
*_*_*_*_*_*_*_*_* 
...X* DECREMENT * 

* SVRB/TASK * 

* SWITCH * 

***************** 


X 

.*. 

G1 

• * *. 

.* WAS *. YES 
*. REMOVED QEL .*... 
*. SHARED .* 

* . . ♦ 

*• •* 

* NO 


.*. NXTINPUT X 


E3 *. 

.* *. 

.* MORE *. YES 
X*. MINOR QCB'S .*...... 

*•ON QUEUE .* X 

*. .* 

*• ■ * • 

* NO 


X 

♦****F3********** 
♦DQELEMNT * 

*-*-*-*-*-*-*-*—* 

* REMOVE *....X 

♦MAJOR QCB FROM * 

* QUEUE * 

***************** 


,X 


*****E4********** 
♦FREEUP * 

*_*_*_*_*_*_*_*_* 

X* FREEMAIN FROM * 

* REMOVED QEL'S * 

* AND/OR QCB'S * 
***************** 

**** 

*24 * 

* F4 *.X. 

* * • 

**** x 

:tinpti .*. 

F4 *. 

• * *• 

.* MORE *. YES 

*.INPUT ENTRIES.*.... 

*. .* 

* • • * • 

*. .* X 

* NO ***** 

. *23 * 

. * Dl* 

. * * 

• * 


• X 

• *****G4********** 

. +RMCOMP 22B1* 

. *-*_*-*-*-*_*-*-* 

,X. * RESET * 

. * MUST-COMPLETE * 

. * * 

• ***************** 




..X. 

I x 

• *****H1********** 
. *DECSVRB 25A1 * 

• *-*-*-*-*-*-*-*-* 

i * DECREMENT * 

. * SVRB/TASK * 

. * SWITCH * 

• ***************** 


X 

*****H4********** 
*MCRET 2 21A4* 

*_*_*_*_*_*_*_*_* 

* CHECK * 

* FOR RETURN * 

* CODES * 

***************** 


X 


J1 *. 

. * *• 

•* MORE *. NO 
*. QEL'S ON .*.. 
*. QUEUE .* 

*• .* 

♦ . . ♦ 

* YES 


X, 


X 

.*• 

K1 *. 

.* *• 

YES •* NEXT *. NO 
...*. QEL SHARED .*..< 
*. .* 

*. .* 

*• •* 

* 


X 

• *. 

J4 *. 

*, ****J5***#***«* 

.*DOES 'NEW* *. YES * * 

*. TCB POINTER ..X* EXIT * 

*.EQ. 'OLD'.* * * 

*. .* *************** 

*• • * 

* NO 


X 

****** 4 ********** 
* * 

* LOAD * 

* EXIT PSW INTO * 

* RB * 

* * 
***************** 


****K5********* 

EXIT 

*************** 
TO DISPATCHER 
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Chart 25. Decrement SVRB/TASK Switch Routine 


DECSVRB 

♦♦♦♦♦Al********** 
* * 

* GET * 

♦POINTER TO SVRB* 

* * 

♦ ♦ 

***************** 


- * ♦. 

♦•RMC REQUESTED.♦ 

♦ • .♦ 

♦ . • ♦ 

♦ YES 


♦ IS SVRB 
WAIT COUNT 
♦. ZERO 


.* WAS *. STEP 

♦.SMC SYSTEM OR.♦. 

♦. STEP .♦ 


X 

*****0 ********** 
* * 
* * 
♦DECREMENT WAIT ♦ 

♦ COUNT * 

♦ ♦ 
***************** 


X 

****♦ 03 ♦♦♦♦*♦* 

* TURN * 

* OFF * 

* SYSTEM-MUST- * 

* COMPLETE FLAG* 

* IN TCB * 
************** 


X 

*****C4******* 

* * 

* TURN OFF * 

* STEP-MUST * 

* COMPLETE FLAG* 

* IN TCB * 
************** 


X 


D1 * • 

.♦ ♦. • 

.* SVRB *. YESX 

♦.STILL WAITING.*.... 
♦ . . * . 

♦ • •♦ 

♦ . .♦ • 
* NO 


X 

***** 03 ********** 
♦SETRSMC 22D1* 

*_*_*_*_*_*_*_*_* 

* SET TCB* S * 

* DISPATCHABLE * 

* * 
***************** 


X 

• *. . 

El *. 

.♦TASK'S *. 

.* PRIORITY *. NO X 
*. HIGHER THAN .*.... 
*•'NEW' TCB.* 

*• .* 

*. .* 

* YES 


X 

*****E3 ******* 

* * 

* RESET * 

* SIRB EXIT *, 

* SWITCH * 

* * 
************** 


ALLOWAX X 

«****E4********** 
* * 

* ALLOW * 

..X* ASYNCHRONOUS * 

* EXITS * 

* * 
***************** 


X 

* ****F1 ******* 

* SET 'NEW* * 

* TCB POINTER * 
♦TO ADDR OF TCB * 

* ENQUELLED ON * 

* RESOURCE * 
************** 


X 


X 

****F4********* 

i EXIT i 

* * 
*************** 

TO CALLING ROUTINE 


X 

****G1********* 


* * 

* EXIT * 

* * 


*************** 


TO CALLING ROUTINE 
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Chart 26. ENQ/DEQ Validity Check Routine 


****A1********* 

* * 

* ENTRY * 

* * 
*************** 



X 

CHKLIST .*. 

B1 *. 

.* *. 

.* * 

*. SYSTEM TASK 

*. •* 

*. .* 

***NO 


****& 2 ** ******* 
YES * * 

*.X* EXIT * 

* * 
*************** 


TO CALLING ROUTINE 


.*. 

Cl *. 

.* *. ****C2********* 

.* *. YES * * 

♦ .MUST/COMPLETE.*.X+ABEND WITH CODE* 

*.REQUESTED.* * = 33X * 

*. .* *************** 

*. .* 


X 

.*• 

D1 *. 

.* PARAM *. 

.* LIST IN *. NO 
*. CALLING 
*. PARTI- .* 

*•TI ON .* 

*. •* 


****D2*+******* 

* * 
,X*ABEND WITH CODE* 
* = 43X * 

*************** 


NOTE: VALUE OF X 
IN ABEND CODE IS 
0 IF ERROR 
ON ENQ 
8 IF ERROR 
ON DEQ 


CHKFRNT 


El *. 

. * *. 
.* MAJOR AND *. 
..X*. MINOR NAMES 
*. IN PRTN .* 
*. •* 


*• .* 

* 


X 

• *. 

FI *. 

.* *. 

.* MINOR *, 

*. NAME LENGTH 
*. VALID .* 

*. .* 

*. .* 

* 


INVALID 

****E2*+******* 
NO * * 

*.X*ABEND WITH CODE* 

X * = 43X * 

. *************** 

**** 

* * 

* E2 * 

* * 

**** 


♦***F2** ******* 
NO * * 

*.....«..X*ABEND WITH CODE* 
* = 23X * 

*************** 



X 

• *. 

G1 *. 

.* *. 

.* ALL *. YES 

*. REQUESTS .*... 
*. CHECKED .* 

*. .* 

*. .* 

* NO 


X 

*+***Hl********** 
* * 

* GET * 

...♦NEXT PARAMETER * 

* * 

* * 

***************** 


X 

****J2********* 

* * 

* EXIT * 

* * 
*************** 

TO CALLING ROUTINE 


X 

.*. 

H2 *. 

.* PARAM *. 

.* LIST *. YES 

♦.EXTENDS PAST .*.... 

*. CALLING .* 

*.PRTN .* • 

* . .* X 

* NO **** 

. * * 

. * E2 * 

. * * 

. **** 
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18K Configuration Load Module Control Flow 



♦♦♦♦A2*SS*SS*SS 
* * 
♦ ENTRY FROM NIP * 


*************** 
. XCTL 


****A5SSSSSSSSS 

♦ ENTRY * 

♦FROM SUPERVISORS 

* ♦ 
*************** 

. XCTL 


*****B 2 S********* 

♦IEFINITL ♦ 

*-*-*_*_*_*-*_*-* 

♦ RDR/INT SX 

♦INITIALIZATION ♦ 

♦ ROUTINE SX 

***************** 

. XCTL 


NOTE 2 X 

♦****C1♦**♦**♦♦** *****C2S♦♦♦♦♦♦♦♦♦ 

♦ SLOAD AND *IEFCNTRL ♦ 

*_*_*_*_*_*_*_*_* x. X S — *—♦ — ♦ — ♦ — ♦—♦ — ♦—* 

.♦ ♦ DEL ETE ♦ RDR/INT ♦ 

.♦MESSAGE MODULES^ SCGNTROL ROUTINES 

♦ ♦ XCTL ♦ ♦ 

***************** X . # .....XSSSSS♦♦♦♦♦♦♦♦♦♦♦♦ 


♦♦♦♦♦Dl♦♦♦♦♦♦♦♦♦♦ 
♦IEFJOB ♦ 

.*_*_*_*_*_ *_*_ *_ * 

♦ SX... 

♦ JOB ROUTINE ♦ 


*****B3********** 

♦IEFPRES ♦ 

*_*_*_*_*-*_*_*_* 
XS VOLUME ♦ 

♦ MOUNTING ♦ 

♦ ROUTINE ♦ 

***************** 


♦***SB4♦♦♦♦♦♦♦♦*♦ 

♦ IEFI DUMP SX 

*_*_*_*_*_*_*-*_* 

♦ ♦ 
♦INDICATIVE DUMPS 
♦ ROUTINE ♦ 
***************** 


XCTL *****B5SS*S*SSSSS 
• XSIEFSTERM ♦ 

XCTL *-*-*-*-*-*-*-*-* 
.♦ STEP SX 

XCTL ♦ TERMINATION ♦ 
.♦ ROUTINE ♦ 

. . . XS♦***♦♦*♦*♦♦♦♦♦** 


*S***C3**♦♦♦♦♦♦♦♦ 

♦ IEFINTFC ♦ 

*-*-*_*-*_*_* 

♦ I NT/I NIT 

♦ INTERFACE 

♦ ROUTINE ♦ 

***************** 


♦X . 


XS JOB ♦ 

♦ TERMINATION ♦ 

♦ ROUTINE ♦ 
***************** 


***************** 


.XCTL 

*****C5S♦♦*♦♦*♦*♦ 

♦ IEF ERROR ♦ 

*_*_*_*_*_*_*_*_* 

♦ JFCB ♦ 

♦ HOUSEKEEPING ♦ 
♦ERROR ROUTINES ♦ 
********.******** 


****** 


*****D4SSSS 

♦ IEFSELCT ♦ 

*_*_*_*_*_*_*_*_* 

♦ SYSTEM SX 

♦CONTROL ROUTINES 

♦ ♦ 
***************** 


******5S♦*♦♦**♦♦♦ 
♦IEFALOC1 ♦ 

CTL *—*—*—♦—*—*—*—*—*XCTL 

.XS ALLOCATION ♦. 

♦CONTROL ROUTINES 
XCTL ♦ ♦ 

...XSSSSSSSSSSSSSSSSS 


XCTL 


*****E1********** 

♦IEFEXEC ♦ 

*_*_*_*_*_*_*_*_* 

♦ SX...X 

♦ EXECUTE ROUTINES 

.♦ ♦ 

***************** 


X 

*****£5S*♦♦*♦♦♦*♦ 
♦IEFAL0C2 ♦ 

*_*_*_*_*_*_*_*_* 

♦ DEMAND ♦ 

♦ ALLOCATION ♦ 

♦ ROUTINE ♦ 
***************** 

X 

. XCTL 



♦****F1********** 
♦IEFDD ♦ 

*_*_*_*_*_*_*_*_* 

♦ SX...X 

♦DD SCAN ROUTINES 

.♦ ♦ 

***************** 


NOTE 1 

*****F 2S♦♦♦♦♦♦♦♦♦ 

♦ IEEMCR 01 ♦ 

*_*_*_*_*_*_*_*_* link 

♦ COMMUNICATION ♦ LI Nk' 

♦ TASK ♦. 

*****************X... 

X . 


*****F3SS*SSS*SSSL0AD AND 

♦ IEEST ART ♦ DELETE 

♦—♦—♦—♦—S—S—S—S—SX.X 

XS START ♦ 

♦COMMAND ROUTINESLINK 

♦ ....... 

***************** 

• XCTL 

• IF 

-ERROR 


*S***F4SS*SSSSSS* 
♦IEEJFCB ♦ 

*_*_*_*_*_*_*_*_* 

♦ JFCB'S FOR ♦ 

♦ START COMMAND ♦ 

♦ ROUTINE ♦ 
***************** 


X 

♦*SS*F5S♦♦♦♦♦♦♦♦♦ 
♦IEFX5000 ♦ 

*_*_*_*_*_*_*_*_* 

♦ DECISION ♦ 

♦ ALLOCATION ♦ 

♦ ROUTINE ♦ 

***************** 

. XCTL 


♦♦♦♦♦Gl♦♦♦♦♦♦♦♦♦♦ 
♦IEFCOMMD ♦ 

*_*-*-*_*-*-*_*_* 

♦ SCAN SX....X 

♦ COMMAND ROUTINES 

♦ ♦ 
***************** 


. X 

. ****SG3SSSSSSSSSS 
• * XSIEEFAULT ♦ 

*_*_*_*_*_*_*_*_* 

.♦ ♦ 

SVC ♦ FAULT ROUTINE ♦ 
EXIT ♦ ♦ 

***************** 
.XCTL 
• IF 

.ERROR 


*****G4S♦♦♦♦♦♦♦♦♦ 
••XSIEESJ FCB ♦ 

*-*_*_*-*_*_*-*_* 
♦INTERFACE WITH ♦ 
♦ TABLE STORE ♦ 
•*X♦ SUBROUTINE ♦ 
***************** 


X 

♦ * * * * G 5S♦♦♦♦♦♦♦♦♦ 

• » XSIEF AL0C3 ♦ 

*—*—*-*_*—*_♦-*-*XCTL 

♦ TIOT S..X. 

♦ CONSTRUCTION ♦ 

♦ ROUTINE ♦ 

***************** . 

• XCTL 


X 

*****H3S*♦♦♦*♦*♦♦ LINK. 

♦ IEESET ♦. 

*—*—*—*—*—*—*—*—*LINK 

....XS SET ♦. 

LINK SCOMMAND ROUTINES (AT I 

♦ S 
***************** 

• XCTL 


*****H4SSSSSSSSSS 
♦IEFJOBQE ♦ 

*_*_*_*_*_*_*_*_* 
..XS QUEUE ♦ 

PL ^INITIALIZATION ♦ 
♦ ROUTINE ♦ 

***************** 


X 

*****H5S♦♦♦*♦♦♦♦♦ 
♦IEFAL0C4 ♦ 

*_*_*_*-*_*_*_*_* 
♦ ♦ 

♦EXTERNAL ACTIONS 
S RCUTINE ♦ 

***************** 
. XCTL 


X 

SSSSSJ3*♦♦♦**♦♦*♦ 
SVC SIEETIME ♦ 
EXIT *-*-*-*-*-*-*-*-* 
...... S 

♦SUPERVISOR TIMES 
♦ ROUTINE ♦ 
***************** 


*****j4********** 

♦IEFATACH ♦ 

*_*_*_*_*_*_*_*_* 

♦ STEP SX 

♦ INITIATION ♦ 

♦ ROUTINE ♦ 

***************** 

.XCTL 


X 

♦SSSSJ5SSSS♦♦♦♦♦♦ 
♦IEFAL0C5 ♦ 

XCTL*—♦—♦—♦—*—♦—♦—♦—♦XCTL 
....* SPACE *.... 

♦ REQUEST ROUTINE* 
s * 

***************** 


NOTE 1 THE ASSEMBLY MODULE IEEMCR0 1 
IS INCLUDED IN LOAD MODULES 
IEFINITL. IEFINTFC, AND 
IEFCOMMD. 

NOTE2 THE MESSAGE MODULES CAN BE 

LOADED AND DELETED BY ANY ONE OF 
THE FOLLOWING MODULES IEFCNTRL, 
IEFJOB, IEFEXEC, IEFDD, AND 
IEFCOMMD. 


X 

**** *« 4********** 

* * 

* SRETURN 

* PROCESSING *. 

* PROGRAM * OR 

* * ABEND 

***************** 


SSSSK5********* 

* EXIT * 

X* TO SUPERVISOR * 

* * 
*************** 
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44K Configuration Load 


Module Control Flow 


****A2+******** 

* ENTRY FROM * 

* NIP * 

* * 
*************** 


****A5********* 

* ENTRY FROM * 

* SUPERVISOR * 

* * 
*************** 




X XCTL 

*****B2********** 

♦ IEFINITL * 

*—*—*—*—*—*—*—*—*XCTL 

♦ RDR/INT *X..., 

♦ INITIALIZATION ♦ 

♦ AND EOF ROUTINE* 
***************** 

.XCTL 


♦****B3********** 
♦IEFPRES ♦ 

*_*_*^*_*_*_*_*_* 
X* VOLUME ♦ 

* MOUNTING ♦ 

* ROUTINE ♦ 

***************** 


*****B4********** 

*IEFI DUMP ♦ 

*-*-*-*-*-*-*-*-* 

* ♦. . 

♦INDICATIVE DUMP* 

♦ ROUTINE ♦ 
***************** 


X 

♦****C1********** *****C2********** 

♦ *LOAD AND * IEFCNTRL * 

*-*-*_*_*_*_*_*_* DELETE *_*_*_*_*_*_*_*_* 

♦ +X.X+ RDR/INT *X. 

♦ MESSAGE MO DULE S+(NO TE 2) ♦ AND JOB * 

♦ * * TERMINATE ♦ 

***************** ***************** 

X .XCTL 


. XCTL 
X 

XCTL *****C5 + + + + ^t + + * 
.... X*IEFSTERM ♦ 

XCTL *-*-*-*-*-*-*-*-* 
• • • • X* INTERFACE AND * 
XCTL * STEP ♦ 

...X* TERMINATION * 
. ***************** 
. .XCTL 


X 

*****D2*+******** 

* IEFCOMMD ,♦ 

LOAD AND DELETE *-*-*-*-*-*-*-*-* 
..X* SCAN * 

(NOTE 2) ♦COMMAND ROUTINE* 

* * 
***************** 


*****04********** 

* IEFERRDR ,* 

*-*_*_*_*_*_*_*_* 

* JFCB * 

* HOUSEKEEPING ♦ 
♦ERROR ROUTINES ♦ 
***************** 


X 

***** 05 *♦**♦***** 

* IEF ALOC1 ♦ 

*-*-*-*_*_*_*_*_* 

* FIRST * 

* LOAD OF ♦ 

* ALLOCATION * 

***************** 

. XCTL 


X 

< < ***^c********** 

* I EF ALCIC2 ♦ 

*-*_*_*_*_*_*-*-* 

* SECOND ♦ 

* LOAD OF ♦ 

* ALLOCATION * 

***************** 

. XCTL 


LI NK 

*****F2**********X 
♦IEEMCROI + LINK 

*-*-*-*-*-*-*-*-*X 

♦ MASTER * 

♦ SCHEDULER +X 

♦ + LINK 
*****************X 


. x*****F3********** *****p 4 ********** 

♦ IEESTART *LOAD AND ♦IEEJFCB * 

*—*—*—*—* — *—*—*—* DE LET E *-*_*-*_*-*-*-*-* 

♦ START *X..X* JFCB'S FOR ♦ 

♦ COMMAND ROUT INE*LINK ♦ START COMMAND * 

♦ ROUTINE ♦ 

***************** 

.XCTL 
.IF 

.ERROR 


+****G3*♦♦****♦♦* 
X^IEEFAULT ♦ 

*_*_*_*_*_*_*_*_* 
SVC ♦ ♦ 

EXIT* FAULT ROUTINE * 


***************** 


***************** 


.XCTL 
.IF 

•ERROR 

♦ ♦♦^(^♦♦♦♦♦♦♦♦♦♦L INK 
♦IEESET *X... 

*_*_*_*_*_*_*_*_* 

X* SET ♦ 

♦COMMAND ROUTINE* LINK 


*****G4********** 
•X*IEESJFCB * 

*_*_*_*_*_*_*_*_* 
♦INTERFACE WITH * 
* TABLE STORE * 
.X* SUBROUTINE * 
***************** 


*X . 


♦****H4********** 
*IEFJOBQE * 

*_*_*_*_*_*_*_*_* 
♦ QUEUE * 

♦INITIALIZATION * 
..X* ROUTINE * 

PL)***************** 


X 

*****F5*******+** 
* * 

* PROCESSING * 

* PROGRAM * 


* * 
***************** 
.RETURN 
. OR 

.ABEND 


X 

****G5********* 

* EXIT TO * 

* SUPERVISOR * 

* * 
*************** 


V/ 


X 

*****j3********** 

SVC *IEETI ME ♦ 

EXIT♦-♦-♦-♦-♦—*-*—*-* 
. . . . * ♦ 
♦SUPERVISOR TIME+ 
♦ ROUTINE ♦ 
***************** 


NOTE 1 IEEMCROI IS NOT A LOAD MODULE. IT IS A CSECT THAT IS 
LINK EDITED INTO MODULES IEFINITL AND IEFCOMMD. 


NOTE 2 THE MESSAGE MODULES CAN 
BE LOADED AND DELETED 
BY IEFCNTRL AND 
IEFCOMMD• 
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Chart 29. 100K Configuration Load Module Control Flow 


****A2********* 

* * 

♦ENTRY FROM NIP * 
♦ ♦ 

*************** 

. XCTL 


X 

*****B2********** 

♦ IEFINITL * 

*_*_*_*_*_*_*_*_* 

♦ R/I * 

♦ INITIALIZATION ♦ 
♦AND EOF ROUTINE* 
***************** 

. XCTL 


♦♦♦♦A3♦♦♦♦♦*♦♦♦ 

♦ ENTRY ♦ 

♦FROM SUPERVISORS 

♦ * 
*************** 


♦♦***B3♦**♦*♦♦♦♦♦ 
♦IEFIDUMP ♦ 

*_*^*_*_*_*_*_*_* 
. X* ♦ 

♦ INDICAT IVE DUMPS 

♦ ROUTINE ♦ 
***************** 


. XCTL 

NOTE 2 XX.... 

*****Cl********** *****C2**********XCTL 

* * * I EF SD Oil *X..... 

*—*—*_*—*—*—*—*—*LOAD AND *-*-*-*-*-*-*-*-* XCTL 

* *X.X* R/I AND *X.. . • < 

* R/I MESSAGES +DELETE * INITIATOR/ * 

* * * TERMINATOR * 

***************** ***************** 

.XCTL 


♦****C3********** 
♦IEFALERR * 

*_*_*_*_*_*_*_*_* 
X* ALLOCATION * 

* ERROR ROUTINE * 

* * 
***************** 


X 

***** 02 ********** 
* * 

* * 

* PROCESSING * 

* PROGRAM * 

* * 
***************** 

. RETURN 
. OR 
. ABEND 


X 

****E2********* 

* EXIT * 

* TO SUPERVISOR * 

* * 
*************** 


NOTE l 


THE ASSEMBLY MODULE 
IEEMCS01 IS INCLUDED 
IN LOAD MODULES 
I EF IN ITL « AND IEFSD011. 


NOTE 2 


THE MESSAGE MODULES 
CAN BE LOADED AND 
DELETED BY IEFSD011. 


NOTE 1 

♦****G3********** 
♦IEEMCS01 * 

*-*-*-*-*-*-*-*-*LINK 

* *..• • 

* COMMUNICATION SLINK 

* TASK *...., 

♦******♦♦**♦**♦**X... 

X 


SVC 
EX IT 


♦ ♦***G4***** ***** 

*IEESTART * 

*—*—*—*—*—*—*—*—*LOAD AND 

X* START .. 

♦COMMAND ROUTINE+DELETE 

* *LINK 

*****************... .. 

• XCTL 
.IF 

.ERROR 


X 

*****H4*SS******* 
X*IEEFAULT * 

*-*-*-*_*-*-*_*-* 

.* * 

* FAULT ROUTINE * 

* * 
***************** 

.XCTL 

.IF 

•ERROR 


X 

*****J 4**********LINK. 
* ♦•««•• 


*****65********** 

* IEEJFCB * 

*-*-*-*-*-*-*-*-* 

X* JFCB'S FOR * 

* START COMMAND * 

* ROUTINE * 
***************** 


**«**H5********** 
♦IEESJFCB * 

X*-*-*-*-*-*-*-*-* 
♦INTERFACE WITH * 
* TABLE STORE * 
X* SUB-ROUTINE * 
***************** 


*****J5********** 

♦IEFJOBQE * 


LINK 


*—*—*—*—*—*—*—*—*L!NK *-*-*-*-*-*-*-*-* 


X* *.X* QUEUE * 

* *(AT I PL) *INITIALIZATION * 

* * * ROUTINE * 


***************** ***************** 
• XCTL 


X 

♦ ****K 4********** 

♦IEETIME * 

SVC *_*_*_*_*_*_*_*_* 

>.....•••.* * 

EXIT +SUPERVISOR TIME* 

* ROUTINE * 
***************** 
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